我们需要编写一个JavaScript函数,该函数接受具有重复条目的数字数组,并将所有重复条目求和到一个索引中。
例如:如果输入数组是-
const input = [1, 3, 1, 3, 5, 7, 5, 4];
输出结果
那么输出应该是-
const output = [2, 6, 7, 10, 4];
//所有重复的值都加到索引0
//所有重复的三分之和加到索引1,依此类推。
因此,让我们为该函数编写代码-
为此的代码将是-
const input = [1, 3, 1, 3, 5, 7, 5, 4]; const mergeDuplicates = arr => { const map = arr.reduce((acc, val) => { if(acc.has(val)){ acc.set(val, acc.get(val) + 1); }else{ acc.set(val, 1); }; return acc; }, new Map()); return Array.from(map, el => el[0] * el[1]); }; console.log(mergeDuplicates(input));
输出结果
控制台中的输出将为-
[ 2, 6, 10, 7, 4 ]