우리는 함수를 작성해야 합니다. 첫 번째 인수로 문자열/숫자 리터럴의 배열 arr을, 두 번째 인수로 숫자 n을 취하는 chunk()를 가정해 보겠습니다.
n 하위 배열의 배열을 반환해야 하며 각 하위 배열에는 최대 −
가 포함됩니다.arr.length / n elements.
요소의 분포는 다음과 같아야 합니다 -
첫 번째 요소는 첫 번째 하위 배열에, 두 번째는 두 번째, 세 번째는 세 번째 등으로 이동합니다. 각 하위 배열에 하나의 요소가 있으면 첫 번째 하위 배열을 두 번째 요소로 채우는 것으로 다시 시작합니다. 마찬가지로, 모든 하위 배열에 두 개의 요소가 있어야만 첫 번째 배열의 세 번째 요소를 채우는 식으로 계속됩니다.
예:입력 배열이 -
인 경우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 ] ]