在数组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
猜你喜欢