我们需要编写一个JavaScript函数,该函数将数字数组作为第一个参数,并将单个数字(例如num)作为第二个参数。Num将始终小于或等于数组的长度。
该函数应准备一个新数组,该数组必须包含num个子数组。如果array的长度可以被num整除,则所有子数组都应包含相等数量的数组,否则,只有最后一个子数组应包含不同数量的元素。
例如-
如果输入数组和数字为-
const arr = [1, 2, 3, 4, 5, 6, 7, 8]; const num = 3;
因此,上述输入的输出应如下所示:
const output = [ [1, 2, 3], [4, 5, 6], [7, 8] ];
为此的代码将是-
const arr = [1, 2, 3, 4, 5, 6, 7, 8];
const num = 3;
const chunkArray = (arr = [], num = 1) => {
const { length: l } = arr;
const elPerArr = Math.ceil(l / num);
const res = arr.reduce((acc, val, ind) => {
const curr = Math.floor(ind / elPerArr);
if(!acc[curr]){
acc[curr] = [val];
}else{
acc[curr].push(val);
}
return acc;
}, []);
return res;
};
console.log(chunkArray(arr, num));输出结果
控制台中的输出将是-
[ [ 1, 2, 3 ], [ 4, 5, 6 ], [ 7, 8 ] ]