统计数组中出现最多的元素

function more(arr) {
        let max=null;//定义一个用来存储出现次数最多的元素
        let num=1;//定义一个用来存储最出现的次数
         arr.reduce((p,k)=>{ //对该数组进行reduce遍历
             p[k]?p[k]++:p[k]=1;
                 if(p[k]>num){
                     num=p[k]
                     max=k
                 }
                 return p
        },{})
        return {max:max,num:num}//返回最多元素对象
    }

这个方法的思路是把整个数组转化为一个伪数组对象:元素和出现的次数以键值对的方式存储。

reduce 的第二个参数是传递给函数的初始值,第一个参数是一个函数。那么此方法中第一次将 {} 传递给了 p 参数,k 参数为当前遍历的对象相当于 Foreach 中的 item 参数

你可能感兴趣的:(算法,javascript,数据结构)