在 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 }
}
广告
数据结构
网络
关系型数据库管理系统
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP