js-查找字符串中出现次数最多的字符

假设有一个字符串,下面让我们一起来查找出现次数最多的字符

1 var str = 'asdfssaaasasasasaa';

 

首先,我们定义一个Object用来存放拆分的字符串,然后遍历字符串。

判断obj里面是否出现某一个字符,如果未出现则给obj添加以此字符为键值的属性,并赋值为1。反之则给此属性值++;

var obj = {};
for (var i = 0; i < str.length; i++) { if (!obj[str.charAt(i)]) { obj[str.charAt(i)] = 1; } else { obj[str.charAt(i)]++ } }

 

此时我们已经拿到了一个这样的对象

var obj ={
    a: 9,
    d: 1,
    f: 1,
    s: 7  
}

 

定义两个变量用来接收出现最多的属性和值,for..in遍历对象的属性。如果obj[i]>max;重新为max赋值,然后一直重复,直到遍历结束拿到出现次数最多的值。

var max = 0,
    name = "";
for (var i in obj) {
    if (obj[i] > max) {
        max = obj[i];
        name = i;
    }
}
console.log('出现次数最多的是:' + name + '出现了' + max + '次'); //出现次数最多的是:a出现了9次 

 

欢迎大家拍砖。。

posted @ 2019-04-30 17:55  胡泊的技术博客  阅读(8344)  评论(0编辑  收藏  举报