查找数组中出现频率第二高的元素 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

更新于: 2020-10-14

536 次浏览

开启你的 职业生涯

完成课程后获得认证

开始
广告