1. 程式人生 > >查詢一個字串中出現頻率最高的字元

查詢一個字串中出現頻率最高的字元

程式碼:

let a='hhhhweeowiohhhlbbccdd';
    a=a.split('');
   // console.log(a instanceof Array);
    function findRes(){
        let result=[];
        let max=0;
        let str='';
        //該迴圈是為了找到各個字元在字串中出現的的次數
        for(let i=0;i<a.length;i++){
             let count=1;
             for(let j=i+1;j<a.length;j++){
                 if(a[i]===a[j]){

                     a.splice(j,1);
                     j--;
                     count++;
                 }
             }
             result.push(a[i]+":"+count);
        }
        console.log(result);
        //["h:7", "w:2", "e:2", "o:2", "i:1", "l:1", "b:2", "c:2", "d:2"]
    //該迴圈是為了在上述得到的結果中找到出現頻率最高的那個字元
        for(let i=0;i<result.length;i++){
            let num=Number(result[i].charAt(2));

            if(max<num){
                max=num;
                str=result[i].charAt(0);
            }

        }
       
        console.log(str+":"+max);
    }
findRes();

執行結果:

在這裡插入圖片描述