前端考题2: 统计字符串中每个字符的出现频率

考题详情:

统计字符串中每个字符的出现频率,返回一个 Object,key 为统计字符,value 为出现频率:
1. 不限制 key 的顺序
2. 输入的字符串参数不会为空
3. 忽略空白字符

示例1:

输入 
'hello world'
输出
{
    
    h: 1, e: 1, l: 3, o: 2, w: 1, r: 1, d: 1}

思路:

  • 首先去除字符串中的空白字符,并将字符串转为数组
  • 创建一个空对象来接收结果
  • 数组遍历,将当前遍历的值作为对象的key,判断该key在对象中是不是存在对应的value,如果不存在就赋值为1,存在就递增1
  • 最后返回这个对象即可

具体代码实现:

function count(str) {
    
    
  let strArr = str.replace(/\s/, '').split('');
  let obj = {
    
    };
  for(var i = 0; i < strArr.length; i++){
    
    
    if(obj[strArr[i]]){
    
    
      obj[strArr[i]]++;
    }else{
    
    
      obj[strArr[i]] = 1;
    }
  }
  return  obj;
}

Guess you like

Origin blog.csdn.net/qq_37600506/article/details/114121189