JS查找字符串中出现次数最多的字符

这篇博客介绍了两种JavaScript方法来统计字符串中字符的出现次数。第一种方法通过indexOf()函数迭代查找目标字符并计数;第二种方法利用对象存储每个字符及其出现次数,再找出出现最多的字符。这两种方法对于字符串分析非常实用。
1. 统计一个字符串中某个字符出现的次数?
  function sum(str, a) {
    let b = str.indexOf(a);
    var num = 0;
    while (b !== -1) {
      console.log(b);
      num++;
      b = str.indexOf(a, b + 1)
    }
    return num;
  }
2. 统计一个字符串中,出现次数最多的字符,出现了多少次?

方法一:

// 统计一个字符,中出现次数最多的字符。
        var str = "zhaochucishuzuiduodezifu";
        var o = {};
        for (var i = 0, l = str.length; i < l; i++) {
            // var char = str[i];
            var char = str.charAt(i);
            if (o[char]) { //char就是对象o的一个属性,o[char]是属性值,o[char]控制出现的次数
                o[char]++; //次数加1
            } else {
                o[char] = 1; //若第一次出现,次数记为1
            }
        }
        console.log(o); //输出的是完整的对象,记录着每一个字符及其出现的次数
        //遍历对象,找到出现次数最多的字符和次数
        var max = 0;
        var maxChar = null;
        for (var key in o) {
            if (max < o[key]) {
                max = o[key]; //max始终储存次数最大的那个
                maxChar = key; //那么对应的字符就是当前的key
            }
        }
        console.log("最多的字符是" + maxChar); // 最多的字符是u
        console.log("出现的次数是" + max); // 出现的次数是5

方法二:

var testStr = 'zhaochucishuzuiduodezifu';
        function fn1(str) {
            var strArr = str.split(''); // 把字符串分割成字符串数组
            var strJson = {};
            var maxLength = 0;//最长的长度
            var value = '';//字符值
            for (var i = 0; i < strArr.length; i++) {
                //没有就创建,每一个不同的字符都用一个数组来存放
                if (!strJson[strArr[i]]) {
                    strJson[strArr[i]] = [];
                }
                strJson[strArr[i]].push(strArr[i]);// 把当前下标的值push进数组
            }
            //遍历json找到最长的
            for (var attr in strJson) {
                if (strJson[attr].length > maxLength) { // 经过比较得到最长的数组
                    maxLength = strJson[attr].length; // 该数组的长度就是出现的次数
                    value = attr;
                }
            }
            return '字符最多的是' + value + ',出现了' + maxLength + '次';
        }
        console.log(fn1(testStr)); // 字符最多的是u,出现了5次
### 找出字符串中出现次数最多字符找出字符串中出现次数最多字符,可以采用以下方法:通过遍历字符串中的每个字符,并使用一个字典或对象来记录每个字符的出现次数。最后,再遍历这个字典或对象以找到出现次数最多字符。 以下是基于 JavaScript 的实现示例[^1]: ```javascript var str = 'ashdfdjklwfiojslkfjdl'; // 测试用的字符串 var l = str.length; var o = {}; for (var i = 0; i < l; i++) { var char = str.charAt(i); if (o[char]) { o[char] += 1; } else { o[char] = 1; } } console.log(o); // 可以打印出对象看看 var max = 0; var ch = ''; for (var k in o) { if (o[k] > max) { max = o[k]; // 储存次数 ch = k; // 储存字符 } } console.log('出现次数最多字符是' + ch + ',它出现了' + max + '次'); ``` 在 Python 中,也可以采用类似的方法[^2]: ```python x = 'hhhhh I love python' z = {} for i in x: if i in z: z[i] += 1 else: z[i] = 1 print(z) # 输出字符及其出现次数 max_char = max(z, key=z.get) max_count = z[max_char] print(f'出现次数最多字符是 {max_char},它出现了 {max_count} 次') ``` 此外,在 C++ 中可以通过数组统计每个字母的出现次数[^4]: ```cpp #include <iostream> using namespace std; int main() { char s[1000]; cin >> s; int b[26] = {0}; int len = 0; for (int i = 0; s[i]; i++) { b[s[i] - 'a']++; len++; } int max = 0; int pos = 0; for (int i = 0; i < 26; i++) { if (b[i] > max) { max = b[i]; pos = i; } } cout << ('a' + pos) << endl; cout << max << endl; } ``` 以上代码展示了如何通过不同的编程语言实现查找字符串中出现次数最多字符的功能。
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值