const arr = ['1', '2', '2', '3', '3', '4', '4', '4', '5', 'b', 'b', 'd', 'd', 'd']
/** 不使用 reduce */
function repeatCount(arr) {
let map = {}
for (let item of arr) {
map[item] = map[item] + 1 || 1
}
return map
}
/** 使用 reduce */
function repeatCountByReduce(arr) {
let map = arr.reduce((prev, curr) => {
prev[curr] = prev[curr] + 1 || 1
return prev
}, {})
return map
}
const obj = repeatCountByReduce(arr) // {1: 1, 2: 2, 3: 2, 4: 3, 5: 1, b: 2, d: 3}
const keys = Object.keys(obj) // ['1', '2', '3', '4', '5', 'b', 'd']
const values = Object.values(obj) // [1, 2, 2, 3, 1, 2, 3]
计算数组中重复元素出现的次数
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- //出现的次数 function times(arr){ var m=0,times=0;//m是数组中的元素,t...
- 需求:编写一个函数,输入数组,输出数组中重复最多的元素,及对应重复次数 这个需求乍看挺简单,但是不花点时间还真搞不...