要求:
对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);