在数组JavaScript中获得最大的重复项
我们有一个数字/字符串文字数组,其中包含一些值(有些也是重复的)。我们的工作是编写一个函数,该函数从数组中返回出现次数最多的元素。
例如-如果输入数组是-
const input = ['a', 'v', 'k', 'f', 'a', 'f', 's', 'd', 'd', 'f', 'a', 'j', 'a'];
那么输出应该是-
'a'
因为“a”被重复最多次数
因此,让我们为此编写代码。我们将使用aMap()
来跟踪遇到的所有元素及其计数,最后返回具有最大计数的元素,如下所示:
示例
const input = ['m', 'a', 'v', 'k', 'f', 'a', 'f', 's', 'd', 'd', 'f', 'a', 'j', 'a']; const findMaximum = arr => { const map = arr.reduce((acc, val) => { let count = acc.get(val); if(count){ acc.set(val, ++count); } else { acc.set(val, 1); }; return acc; }, new Map()); return Array.from(map).reduce((acc, val) => { if(val[1] > acc[1]){ return val; }; return acc; }, [0, 0])[0]; }; console.log(findMaximum(input));
输出结果
控制台中的输出将为-
a