在 JavaScript 陣列中查找出現頻率最高的數字以及重複次數


我們需要編寫一個 JavaScript 函式,它接受一個文字陣列作為輸入,並找出陣列中最常出現的數字以及出現的次數。

示例

程式碼如下:

const arr = ['13', '4', '1', '1', '4', '2', '3', '4', '4', '1', '2', '4', '9', '3'];
const findFrequency = (arr = []) => {
   const count = {};
   const max = arr.reduce((acc, val, ind) => {
      count[val] = (count[val] || 0) + 1;
      if (!ind || count[val] > count[acc[0]]) {
         return [val];
      };
      if (val !== acc[0] && count[val] === count[acc[0]]) {
         acc.push(val);
      };
      return acc;
   }, undefined);
   return {
      max, count
   };
}
console.log(findFrequency(arr));

輸出

控制檯中的輸出為:

{
   max: [ '4' ],
   count: { '1': 3, '2': 2, '3': 2, '4': 5, '9': 1, '13': 1 }
}

更新於:2020 年 11 月 23 日

242 次瀏覽

啟動你的職業生涯

完成課程以獲得認證

開始
廣告