分析
题目的意思大致就是找出每个字符出现的次数,然后比较大小。那么每个字符都应该对应它出现的次数。既然是一一对应的,那我们就想到用对象的key和value来储存字符和其出现的次数。
具体做法
- 新建一个空对象
obj - 遍历给定的字符串
- 接下来就是最重要的 把字符作为
key值,对应次数作为value添加给obj。 - 判断
obj是否存在当前循环的字符,有则让value即次数++,否则把当前项作为key添加给obj。 - 然后是比较次数的大小。
- 这时我们需要一个变量来储存
obj的value值。 - 声明一个变量
num,并设置初始值为0。 - 遍历
obj,比较其value值与num值的大小。大则将其value值赋给num,否则num值不变,从而找出最大的value值。 - 这时我们需要一个数组来储存与最大的
value值即num匹配的key值。因为这样的key值可能不止一个,所以用一个数组来储存。 - 新建一个空数组
keys。 - 遍历
obj,判断与num匹配的key值,并添加在keys内。 - 因为
keys是个数组,需要用join转换成字符串。 - 最后就可以返回出现次数最多的字符及次数了。
let str = "http://www.sxqyuming.com";
function word(str){let obj = {};let num = 0;let keys = [];for(var i=0;i<str.length;i++){let strs = str[i]if(!obj[strs]){obj[strs] = 1;}else{obj[strs]++}}for(var i in obj){if(num<obj[i]){num = obj[i]}}for(var i in obj){if(obj[i]==num){keys.push(i)}}return "出现次数最多的字符为"+keys.join('和')+",出现次数为"+num+"次。"
}
console.log(word(str))