任意给定一个字符串,能够找出里面出现频率最高的的字符,以及出现的具体次数。

本文介绍了一种算法,用于从任意给定的字符串中找出出现频率最高的字符及其具体次数。通过两种不同的实现方式,展示了如何使用JavaScript进行高效字符计数和频率分析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.问题描述:

任意给定一个字符串,能够找出里面出现频率最高的的字符,以及出现的具体次数。

2.解决办法一:

let s='hellooworld';
     function f(s){
         //获取到每个字符对应出现的次数
         let obj={};//用来接收
         let finalObj=[];//用来存储出现次数最多的字符信息
         let len=s.length;
         for(let i=0;i<len;i++){
            //首先判断对应字符是否在obj这个对象中,若在,则出现的次数叠加,
             //否则,则赋予初始值1
             let char=s[i];
             if(obj[char]){
                 obj[char]++;

             }else{
                 obj[char]=1;
             }
         }
         //console.log(obj);
         //找出出现次数最多的那一项所对应的次数
         let max=0;//初始值
         for(let i in obj){
             if(max<obj[i]){
                 max=obj[i];
             }
         }
         //获取到出现的最多次数(有一种情况是有多个字符出现的次数是一样多的)
         for(let i in obj){
             if(obj[i]===max){
               finalObj.push({"字符":i,"出现的最多的次数":obj[i]})
             }
         }
         console.log(finalObj);
     }
     f(s);

解决方法二:

    <!-- 获取一个字符串中出现最多的字符及出现的次数 -->
    <script>
        var s='gggshd';
        //
        function num(str){
          var res=[],final={};
          str=str.split('');

          for(let i=0;i<str.length;i++){
              debugger
              var s=str[i];
              var count=1;
              for(let j=i+1;j<str.length;j++){
                  debugger
                 if(str[j]==s){
                    count++;
                    str.splice(j,1);
                    j--;
                 }
              }
              res.push({
                  name:s,
                  count
              });

          };
          final.max=0;
          for(let i of res){
              debugger
             
              if(i.count>=final.max){
                  final.max=i.count;
                  final.name=i.name;
              }
          };
          console.log(final)
        };
        num(s);
        
    </script>

3.总结:

该问题的解决思路为:
(1)找出每个字符对应的次数
(2)找出出现次数最多的字符

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值