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次
欢迎大家拍砖。。