题目描述
输入
[1, 2, 4, 4, 3, 4, 3], 4
输出
3
第一种::运用reduce的第二个参数设置回调中的allEle为{}对象,去计算arr中每个元素出现的次数,然后再返回item的出现次数
function count(arr, item) {
var o = arr.reduce(function(allEle,curValue,index,arr){
if(curValue in allEle){
allEle[curValue]++;
}else{
allEle[curValue] = 1;
}
return allEle;
},{});
if(o[item]){
return o[item];
}
return 0;
}
第二种::可以成为精明之作,reduce的第二个参数设置为0则prev就为0,然后使arr的当前和item做比较,相等则prev加1,最后返回返回值。
//reduce()-->从数组的第一项开始,逐个遍历到最后;
function count(arr, item) {
var count = arr.reduce(function(prev, curr) {
return curr === item ? prev+1 : prev;
}, 0);
return count;
}
第三种::遍历数组,相等则count加1
function count(arr, item) {
var count = 0;
for(var i = 0; i < arr.length; i++){
if(arr[i] === item){
count++;
}
}
return count;
}
第四种::使用filter返回与item相等的true值的元素ele后返回新数组,最后返回新数组中都是item相等的元素数组长度。
function count(arr, item) {
var m = arr.filter(function(ele,index,arr){
return ele === item;
});
return m.length;
}