예를 들어 문자열/숫자 리터럴의 배열 arr를 첫 번째 인수로, 숫자 n을 두 번째 인수로 취하는 함수를 작성해야 한다고 가정해 보겠습니다.
각각 최대 arr.length / n 요소를 포함하는 n 하위 배열의 배열을 반환해야 합니다. 그리고 요소의 분포는 다음과 같아야 합니다 -
- 첫 번째 요소는 첫 번째 하위 배열에, 두 번째는 두 번째, 세 번째는 세 번째 등으로 이동합니다.
- 각 하위 배열에 하나의 요소가 있으면 첫 번째 하위 배열을 두 번째 요소로 채우는 것으로 다시 시작합니다.
- 마찬가지로, 모든 하위 배열에 두 개의 요소가 있어야만 첫 번째 배열의 세 번째 요소를 채우는 식으로 계속됩니다.
예를 들어 -
입력 배열이 -
인 경우const input = [656, 756, 5345, 67, 43, 76, 54, 768, 34];
숫자 n이 3이면 출력은 -
const output = [ [ 656, 67, 54 ], [ 756, 43, 768 ], [ 5345, 76, 34 ] ];
원하는 배열을 구성하기 위해 원래 배열에 대해 Array.prototype.reduce() 메서드를 사용합니다.
예시
다음은 코드입니다 -
const input = [656, 756, 5345, 67, 43, 76, 54, 768, 34]; const divideArray = (arr, size) => { return arr.reduce((acc, val, ind) => { const subIndex = ind % size; if(!Array.isArray(acc[subIndex])){ acc[subIndex] = [val]; }else{ acc[subIndex].push(val); }; return acc; }, []); }; console.log(divideArray(input, 3));
출력
이것은 콘솔에 다음과 같은 출력을 생성합니다 -
[ [ 656, 67, 54 ], [ 756, 43, 768 ], [ 5345, 76, 34 ] ]