[프로그래머스] 2차원으로 만들기


문제 설명

정수 배열 num_list와 정수 n이 매개변수로 주어집니다. num_list를 다음 설명과 같이 2차원 배열로 바꿔 return하도록 solution 함수를 완성해주세요.

num_list가 [1, 2, 3, 4, 5, 6, 7, 8] 로 길이가 8이고 n이 2이므로 num_list를 2 * 4 배열로 다음과 같이 변경합니다. 2차원으로 바꿀 때에는 num_list의 원소들을 앞에서부터 n개씩 나눠 2차원 배열로 변경합니다.

num_listnresult
[1, 2, 3, 4, 5, 6, 7, 8]2[[1, 2], [3, 4], [5, 6], [7, 8]]

제한사항

  • num_list의 길이는 n의 배 수개입니다.
  • 0 ≤ num_list의 길이 ≤ 150
  • 2 ≤ n < num_list의 길이
  • before와 after는 모두 소문자로 이루어져 있습니다.

입출력 예

num_listnresult
[1, 2, 3, 4, 5, 6, 7, 8]2[[1, 2], [3, 4], [5, 6], [7, 8]]
[100, 95, 2, 4, 5, 6, 18, 33, 948]3[[100, 95, 2], [4, 5, 6], [18, 33, 948]]

입출력 예 설명

입출력 예 #1

  • num_list가 [1, 2, 3, 4, 5, 6, 7, 8] 로 길이가 8이고 n이 2이므로 2 * 4 배열로 변경한 [[1, 2], [3, 4], [5, 6], [7, 8]] 을 return합니다.

입출력 예 #2

  • num_list가 [100, 95, 2, 4, 5, 6, 18, 33, 948] 로 길이가 9이고 n이 3이므로 3 * 3 배열로 변경한 [[100, 95, 2], [4, 5, 6], [18, 33, 948]] 을 return합니다.

나의 풀이

function solution(num_list, n) {
  var answer = [];
  for (i = 0; i < num_list.length; ) {
    var twoDimensions = [];
    for (j = 0; j < n; j++) {
      twoDimensions.push(num_list[i]);
      i++;
    }
    answer.push(twoDimensions);
  }
  return answer;
}

나의 두번째 풀이(Code Refactoring)

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

// 이전 코드에선 중첩 반복문으로 사용했지만 그럴 필요가 없었다
// 1. num_list 배열 루프를 생성하고 i+=n으로 n의 요소만큼 건너 뛰어서 순회한다
// 2. slice로 초기 배열에 push한다
// 3. 예시로 num_list의 i의 0번째 인덱스 값 1과 0번째 인덱스 + n 값을 잘라 넣는다
// 4. 0번째 인덱스 3번째 인덱스를 잘라서 리턴한다

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

function solution(num_list, n) {
  var answer = [];

  while (num_list.length) {
    answer.push(num_list.splice(0, n));
  }

  return answer;
}

// while을 사용하여 순회하는 방법