假设我们需要编写一个函数,该函数接受一个Numbers和number n数组,其中n> =该数组的任何数字。如果数组的连续元素之和超过数字n,则需要使用该函数将数组分成子数组。
例如-
// if the original array is: const arr = [2, 1, 2, 1, 1, 1, 1, 1]; //并且数字n为4- //那么输出数组应该是: const output = [ [ 2, 1 ], [ 2, 1, 1 ], [ 1, 1, 1 ] ];
让我们为该函数编写代码-
const arr = [2, 1, 2, 1, 1, 1, 1, 1];
const splitArray = (arr, num) => {
return arr.reduce((acc, val, ind) => {
let { sum, res } = acc;
if(ind === 0){
return {sum: val, res:[[val]]};
};
if(sum + val <= num){
res[res.length-1].push(val);
sum +=val;
}else{
res.push([val]);
sum = val;
};
return { sum, res };
}, {
sum: 0,
res: []
}).res;
};
console.log(splitArray(arr, 4));
console.log(splitArray(arr, 5));输出结果
控制台中的输出将为-
[ [ 2, 1 ], [ 2, 1, 1 ], [ 1, 1, 1 ] ] [ [ 2, 1, 2 ], [ 1, 1, 1, 1, 1 ] ]