假設有一個字符串,下面讓我們一起來查找出現次數最多的字符
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次
歡迎大家拍磚。。