如何获取字符串中,出现频率最高的字符?

要求:

对String做扩展,实现如下方式获取字符串中频率最高的字符
var str = 'ahbbccdeddddfg';
var ch = str.getMostOften();
console.log(ch)  //出现最多的是d,出现了5次
思路:我们先声明一个空对象,然后遍历字符串,把字符串出现过的字母作为对象的属性,把字母出现过的次数,作为属性值。看代码。
var str = 'ahbbccdeddddfg';
String.prototype.getMostOften= function(){
var obj = {}    // key(字母):value(次数)
for(var i =0;i<str.length;i++){
    var letter = str.charAt(i);  //letter存放每个字母
    if(!obj[letter]){
      obj[letter] = 1;
    }else{
      obj[letter]++;
    }
}
console.log(obj);   //输出一个obj  {a: 1, h: 1, b: 2, c: 2, d: 5, …}
var maxIdx = 0;  //存放出现最多的次数
var maxLet = ''   //存放出现次数最多的字母
for(var key in obj){
    if(maxIdx<obj[key]){
        maxIdx = obj[key];
        maxLet = key;
    }
}
 return  console.log('字符串中出现次数最多的字母是 '+maxLet+'; 出现的次数是:'+maxIdx+'次;')
}
str.getMostOften();  
//字符串中出现评率最高的字母是 d; 出现的次数是:5次;
还有一种方法:
let str = 'aabcdhjeeffjjaaaplma';
function getMax(str){
    let obj = {};
    for(let i in str){
        if(obj[str[i]]){
          obj[str[i]]++;
        }else{
          obj[str[i]]= 1;
        }
    }
    //Object.keys() 方法会返回一个由一个给定对象的自身可枚举属性组 成的数组
    //数组中属性名的排列顺序和使用 for...in 循环遍历该对象时返回的顺序一致 。
    let keys = Object.keys(obj);  //获取对象中,所有key的返回值数组


    //Object.values()方法返回一个给定对象自身的所有可枚举属性值的数组,
    //值的顺序与使用for...in循环的顺序相同 ( 区别在于 for-in 循环枚举原型链中的属性 )。
    let values = Object.values(obj)   //获取对象中,所有value返回数组
    let maxVal = Math.max(...values);
    console.log('出现最多的字母是:'+keys[values.indexOf(maxVal)]+'; 出现次数是:'+maxVal+'次;')
}
getMax(str);
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容