[프로그래머스] 잘라서 배열로 저장하기


문제 설명

문자열 my_str과 n이 매개변수로 주어질 때, my_str을 길이 n씩 잘라서 저장한 배열을 return하도록 solution 함수를 완성해주세요.


제한사항

  • 1 ≤ my_str의 길이 ≤ 100
  • 1 ≤ n ≤ my_str의 길이
  • my_str은 알파벳 소문자, 대문자, 숫자로 이루어져 있습니다.

입출력 예

my_strnresult
“abc1Addfggg4556b”6[“abc1Ad”, “dfggg4”, “556b”]
“abcdef123”3[“abc”, “def”, “123”]

입출력 예 설명

입출력 예 #1

  • “abc1Addfggg4556b” 를 길이 6씩 잘라 배열에 저장한 [“abc1Ad”, “dfggg4”, “556b”]를 return해야 합니다.

입출력 예 #2

  • “abcdef123” 를 길이 3씩 잘라 배열에 저장한 [“abc”, “def”, “123”]를 return해야 합니다.

유의사항

  • 입출력 예 #1의 경우 “abc1Addfggg4556b”를 길이 6씩 자르면 “abc1Ad”, “dfggg4” 두개와 마지막 “556b”가 남습니다. 이런 경우 남은 문자열을 그대로 배열에 저장합니다.

나의 풀이

function solution(my_str, n) {
  var answer = [...my_str];
  let result = [];

  while (answer.length > 0) {
    result.push(answer.splice(0, n).join(""));
  }
  return result;
}

나의 두번째 풀이(Code Refactoring)

function solution(my_str, n) {
  let result = [];
  for (i = 0; i < my_str.length; i += n) {
    result.push(my_str.slice(i, n + i));
  }
  return result;
}

참고 할 만한 다른 사람의 코드

function solution(my_str, n) {
  return my_str.match(new RegExp(`.{1,${n}}`, "g"));
}

// 1. 정규식을 이용한 풀이 방법