5 回答

TA貢獻(xiàn)1842條經(jīng)驗(yàn) 獲得超13個(gè)贊
o[char]就是記錄每個(gè)元素出現(xiàn)的次數(shù)的。
例如第一個(gè)元素是a,走到這里 o['a']是undefined 那就會(huì)走else o['a'] = 1,記錄一次。
后面再有元素的a的話 o['a'] 就為真了 走if o['a']++,次數(shù)就會(huì)增加一次了!

TA貢獻(xiàn)1909條經(jīng)驗(yàn) 獲得超7個(gè)贊
要理解下js的對(duì)象,是{key,value}的關(guān)系的,如果key不存在, 則o.key就是undefined(if判斷里面就是false), 如果存在o.key,對(duì)應(yīng)的數(shù)據(jù)就是value。 而o.key = 1的意思就是給o添加一個(gè)key,對(duì)應(yīng)的值是1.
拿第一次說(shuō),o['z'],就是o.z 肯定是undefined,就到了else 分支,之后o.z就等于1。下次再碰到'z'字符串,就到了次數(shù)加1的分支
if (o[char]) {
o[char]++; //次數(shù)加1
} else {
o[char] = 1; //若第一次出現(xiàn),次數(shù)記為1
}

TA貢獻(xiàn)1872條經(jīng)驗(yàn) 獲得超4個(gè)贊
var str = "zhaochucichuzuiduodezifu";
var strCounter = {};
var maxCount = 0;
var resC = '';
for (var i in str) {
var c = str[i];
strCounter[c] ? strCounter[c]++ : (strCounter[c] = 1);
if (strCounter[c] > maxCount) {
maxCount = strCounter[c];
resC = c;
}
}
console.log('strCount', strCounter);
console.log('resC', resC);

TA貢獻(xiàn)1773條經(jīng)驗(yàn) 獲得超3個(gè)贊
//判斷一個(gè)字符串中出現(xiàn)次數(shù)最多的字符,并統(tǒng)計(jì)這個(gè)次數(shù)
var str = 'asdsdddd';
console.log(str)
var obj = {};
for(var i=0;i<str.length;i++){
var strIndex = str.charAt(i);
if(obj[strIndex]){
obj[strIndex]++;
}else{
obj[strIndex] = 1;
}
}
console.log(obj)
var max = 0;
for(var key in obj){
if(max < obj[key]){
max = obj[key]
}
}
for(var key in obj){
if(obj[key] == max){
console.log('出現(xiàn)次數(shù)最多的是'+key);
console.log('次數(shù)是'+max);
}
}

TA貢獻(xiàn)1844條經(jīng)驗(yàn) 獲得超8個(gè)贊
function countMaxStr(str){
var o = {}
str.split('').forEach(item=>{
if(item in o){
o[item]++
}
else {
o[item] = 1
}
})
return sortObj(o)
}
function sortObj(obj){
var arr = []
for(var key in obj){
arr.push({
key:key,
value:obj[key]
})
}
arr.sort((a,b)=>{
return a.value > b.value
})
return arr.pop()
}
console.log(countMaxStr("121313fefefrg"))
添加回答
舉報(bào)