统计字符出现的次数并排序

深刻了解到数组的reduce方法


题目

给定字符串'strhvcvgjfdcvvvsxsy'

统计各个字符出现的频率

拿到自己解法是:

let str = 'strhvcvgjfdcvvvsxsy'

const obj = {}
str.split('').forEach((item) => {
  if (obj[item]) {
    obj[item] += 1
  } else {
    obj[item] = 1
  }
})

let newArr = []
for (key in obj) {
  const newObj = {}
  newObj[key] = obj[key]
  newArr.push(newObj)
}

newArr.sort((a, b) => {
  return b[Object.keys(b)] - a[Object.keys(a)]
})

const count = {}
newArr.forEach((item) => {
  count[Object.keys(item)] = item[Object.keys(item)]
})

console.log(count)

学习到的方法:用reduce

// 统计出现频率
const result = str.split('').reduce((a, b) => {
  if (a[b]) {
    a[b]++
  } else {
    a[b] = 1
  }
  return a
}, {})

简化

使用 || 或逻辑,还有return的()括号函数

return (xxx, xxxx, xxxxx, aaaa)

括号内不管有多少,都只返回最后一位aaaa

const result2 = str.split('').reduce((a, b) => (a[b]++ || (a[b] = 1), a), {})
const arr = Object.entries(result2).sort((a, b) => a[1] - b[1]).reduce((a, b) => ((a[b[0]] = b[1]), a), {})

重点:reduce方法

reduce((pre, cur, index) => {}, n)   n为初始值,默认为0

一般常用于数组求和

过程就是

  • 参数a先为初始值0, b为数组的第一个值 , 一轮过后为 0 + 1 = 1
  • 第二轮a为上一轮的结果1, b为数组的第二个值,则为1 + 5 = 6
const a = [1, 5]
const num = a.reduce((a, b) => a + b, 0)

console.log(num)

总结

即初始值设为{}时,a就是{},a[b] = 1 ===>  {s: 1}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值