假设我们必须编写一个函数,该函数接受一个数组并返回另一个数组,该数组中连续的相似数字加在一起。
例如-
const array = [1, 5, 5, 5, 8, 8, 9, 1, 4, 4, 2];
输出应为-
[1, 15, 16, 9, 1, 8, 2]
所有连续的5加起来等于15,然后2个连续的8加起来就是16,类似的4加起来就是8。
因此,让我们为该函数编写代码。我们将在这里使用Array.prototype.reduce()方法来减少原始数组并同时构造一个新数组。
const array = [1, 5, 5, 5, 8, 8, 9, 1, 4, 4, 2]; const sumConsecutive = (array) => { return array.reduce((acc, val) => { if (acc.last === val) { acc.arr[acc.arr.length - 1] += val; } else { acc.arr.push(val); acc.last = val; } return acc; }, { arr: [], last: undefined }).arr; }; console.log(sumConsecutive(array));
输出结果
控制台中的输出将为-
[ 1, 15, 16, 9, 1, 8, 2 ]