在想一个js算法,如何算出数组所有项的出现次数

比如 var arr = [1, 2, 3, 1, 5, 8, 2, 9, 9, 2, 2, 2, 3];

如何才能能够算出,数组中有几种值,以及某种值出现的次数呢?

比如这个题答案就是:  
数组中出现的元素值为:1, 2, 3, 5, 8, 9这几个。
其中1出现次数为2次,2出现次数为5次,3出现次数为2次,5出现次数为1次,8出现次数为1次,9出现次数为2次。

各位大佬有什么思路吗?

如果您有思路,可以给小弟来个评论,实现方法多多益善~~~
阅读 990
评论
    7 个回答
    var arr = [1, 2, 3, 1, 5, 8, 2, 9, 9, 2, 2, 2, 3];
    var tempArr = Array.from(new Set(arr)); // 去重
    var countArray = tempArr.map(function(item){
        var count = arr.filter(function(arrItem){return item == arrItem});
        return {
            value: item,
            count: count.length || 0
        };
    });

    当然我这种比较简单..只支持数字或字符串