查找数组中第二常见的字符-JavaScript

我们需要编写一个JavaScript函数,该函数接受一个字符串,并从出现次数第二多的字符串中返回该字符。

假设以下是我们的数组-

const arr = [1, 34, 4, 3, 2, 1, 4, 6, 4, 6, 5, 3, 6, 6];

因此,频繁出现的字符是-

6

但是我们希望输出是第二频繁出现的字符,即

4

让我们为该函数编写代码-

示例

const arr = [1, 34, 4, 3, 2, 1, 4, 6, 4, 6, 5, 3, 6, 6];
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));

输出结果

以下是控制台中的输出-

4
猜你喜欢