在 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 } }
廣告