查找数组中出现频率第二高的元素 JavaScript
我们需要编写一个 JavaScript 函数,该函数接受一个字符串,然后返回出现在字符串中次数第二多的字符。
示例
代码如下 −
const arr = [5, 2, 6, 7, 54, 3, 2, 2, 5, 6, 7, 5, 3, 5, 3, 4]; const secondMostFrequent = 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); const frequencyArray = Array.from(map); return frequencyArray.sort((a, b) => { return b[1] - a[1]; })[1][0]; }; console.log(secondMostFrequent(arr));
输出
控制台输出 −
2
广告