在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問答/HTML/ 關(guān)于一道面試題,js中查找字符串中出現(xiàn)次數(shù)最多的字符

關(guān)于一道面試題,js中查找字符串中出現(xiàn)次數(shù)最多的字符

<script>
var str = "zhaochucichuzuiduodezifu";
var o = {};
for (var i = 0, length = str.length; i < length; i++) {
// var char = str[i];
var char = str.charAt(i);
if (o[char]) { //char就是對象o的一個屬性,o[char]是屬性值,o[char]控制出現(xiàn)的次數(shù)
o[char]++; //次數(shù)加1
} else {
o[char] = 1; //若第一次出現(xiàn),次數(shù)記為1
}
}
console.log(o); //輸出的是完整的對象,記錄著每一個字符及其出現(xiàn)的次數(shù)
//遍歷對象,找到出現(xiàn)次數(shù)最多的字符和次數(shù)
var max = 0;
var maxChar = null;
for (var key in o) {
if (max < o[key]) {
max = o[key]; //max始終儲存次數(shù)最大的那個
maxChar = key; //那么對應(yīng)的字符就是當(dāng)前的key
}
}
console.log("最多的字符是" + maxChar);
console.log("出現(xiàn)的次數(shù)是" + max);
</script>

網(wǎng)上找到的一種方法
其中 if (o[char]) 這里沒看懂。如果單純的輸出o[char]肯定為什么undefined執(zhí)行了else使他為1然后執(zhí)行 也只執(zhí)行一次。 為什么最后會輸出一個0的對象著實不明白。這個key vaule是這么加入到這個對象里的

回答
編輯回答
故林

o[char]就是記錄每個元素出現(xiàn)的次數(shù)的。
例如第一個元素是a,走到這里 o['a']是undefined 那就會走else o['a'] = 1,記錄一次。
后面再有元素的a的話 o['a'] 就為真了 走if o['a']++,次數(shù)就會增加一次了!

2018年4月18日 07:56
編輯回答
純妹

要理解下js的對象,是{key,value}的關(guān)系的,如果key不存在, 則o.key就是undefined(if判斷里面就是false), 如果存在o.key,對應(yīng)的數(shù)據(jù)就是value。 而o.key = 1的意思就是給o添加一個key,對應(yīng)的值是1.
拿第一次說,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
}
2018年4月1日 05:49
編輯回答
玄鳥
//判斷一個字符串中出現(xiàn)次數(shù)最多的字符,并統(tǒng)計這個次數(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);
            }
        }
2018年2月14日 11:02
編輯回答
奧特蛋
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"))
2017年1月24日 05:22
編輯回答
孤島
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);
2018年8月2日 15:26