JS判断一个字符串中出现次数最多的字符并统计次数

题目

写一个函数判断一个字符串中出现次数最多的字符,并统计这个字符出现的次数。比如有这样一个字符串:“daskljahiagnaknscsjdwfanalvnahdpwod”。

解题方法

1-遍历对比

var str = "daskljahiagnaknscsjdwfanalvnahdpwod";

function max() {
  var o = {};
  for (var i = 0; i < str.length; i++) {
      // 循环遍历
    var item = str.charAt(i);
    if (o[item]) {
      o[item]++;
    } else {
      o[item] = 1;
    }
  }
  var max = 0; // 出现次数
  // 标记出现次数最大字符
  for (var key in o) {
    if (max < o[key]) {
      max = o[key];
      var tmp;
      tmp = key;
    }
  }
  console.log("出现次数最多的字符是:" + tmp + "出现次数为:" + max);
}

max(str);

运行结果

出现次数最多的字符是:a
出现次数为:7

2-字符排序归类,遍历数组看是否字符相同
类似如下

var x = "daskljahiagnaknscsjdwfanalvnahdpwod";
var y = x.split("").sort().join("");
console.log(x)
console.log(y)

结果如下

daskljahiagnaknscsjdwfanalvnahdpwod
aaaaaaacddddfghhijjkkllnnnnopsssvww


对于正题,全部代码如下


var x = "daskljahiagnaknscsjdwfanalvnahdpwod";
var y = x.split("").sort().join("");

function move(str){
    result = []; // 储存结果
    // console.log(n);
    var key; //储存上一个循环的指针位置
    for (var i = 0; i < str.length; i++) {
        var key;
        for(;str[i] != str[i+1];i++){
            // console.log(str[i]);
            if(result.length==0){
                result[str[i]] = i + 1; // 以字符为下标储存i的差值

            }else{
                result[str[i]] = i-key;
            }
            result.length++; // result[str[i]] = i + 1;用这种格式加入,数组长度不会改变,手动改一下
            key = i;
        }
    }
    console.table(result); // 表格形式输出数组
    var max = 0; //出现次数
    var tmp;

    for (index in result){
        if (max < result[index]) {
                  max = result[index];
                  tmp = index;
        }
    }
    console.log("出现次数最多的字符是:" + tmp + "\n出现次数为:" + max);
}
move(y);

运行结果

[
<16 empty items>, a: 7,
c: 1, d: 4,
f: 1, g: 1,
h: 2, i: 1,
j: 2, k: 2,
l: 2, n: 4,
o: 1, p: 1,
s: 3, v: 1,
w: 2
]
出现次数最多的字符是:a
出现次数为:7

  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用以下代码来判断一个字符串出现次数最多字符: ``` function maxChar(str) { let charMap = {}; let maxNum = 0; let maxChar = ''; for (let char of str) { if (charMap[char]) { charMap[char]++; } else { charMap[char] = 1; } } for (let char in charMap) { if (charMap[char] > maxNum) { maxNum = charMap[char]; maxChar = char; } } return maxChar; } ``` 首先,通过遍历字符串的每个字符统计它们在字符串出现次数,并存储在一个字典。 然后,再遍历这个字典,找到出现次数最多字符并返回它。 ### 回答2: 可以使用JavaScript编写一个函数来判断一个字符串出现次数最多字符。首先,我们可以定义一个空对象来存储每个字符出现次数,然后遍历字符串的每个字符,将其添加到对象作为键,如果字符已经存在,则将对应的值加1,如果不存在,则将其作为新的键,并将值设置为1。最后,我们可以遍历对象找到值最大的键,即为出现次数最多字符。 下面是一个示例代码: ```javascript function findMostFrequentChar(str) { var charCount = {}; // 用于存储字符出现次数的对象 // 遍历字符串的每个字符 for (var i = 0; i < str.length; i++) { var char = str[i]; // 判断字符是否存在于对象 if (charCount[char]) { // 若存在,则将对应的值加1 charCount[char]++; } else { // 若不存在,则将其作为新的键,并将值设置为1 charCount[char] = 1; } } var maxCount = 0; // 最大出现次数字符次数 var mostFrequentChar = ''; // 出现次数最多字符 // 遍历对象,找到值最大的键 for (var char in charCount) { if (charCount[char] > maxCount) { maxCount = charCount[char]; mostFrequentChar = char; } } return mostFrequentChar; } var str = 'abcaabbbccc'; var mostFrequentChar = findMostFrequentChar(str); console.log('出现次数最多字符是:' + mostFrequentChar); ``` 以上代码输出的结果是:出现次数最多字符是:b ### 回答3: 要用JavaScript语言判断一个字符串出现次数最多字符,可以按照以下步骤进行: 1. 首先,创建一个空对象来存储字符出现次数。 2. 遍历字符串的每个字符,对每个字符进行以下操作: - 如果在对象已经存在该字符的键,则将该键的值加1。 - 如果在对象不存在该字符的键,则将该字符作为键,并将值设为1。 3. 遍历完所有字符后,再次遍历对象,找到值最大的键。 4. 输出最大值对应的键即为字符串出现次数最多字符。 下面是一个实现此功能的JavaScript代码示例: ```javascript function findMostFrequentChar(str) { let charCount = {}; // 创建一个空对象用于存储出现次数 // 遍历字符串的每个字符 for (let char of str) { if (charCount[char]) { charCount[char]++; // 如果已存在该字符的键,值加1 } else { charCount[char] = 1; // 如果不存在该字符的键,将键设为字符,值设为1 } } let maxCount = 0; // 记录最大值 let mostFrequentChar = ''; // 记录出现次数最多字符 // 遍历对象,找到最大值对应的键 for (let char in charCount) { if (charCount[char] > maxCount) { maxCount = charCount[char]; mostFrequentChar = char; } } return mostFrequentChar; // 返回出现次数最多字符 } // 示例用法 let str = "abcccddddd"; let mostFrequentChar = findMostFrequentChar(str); console.log("出现次数最多字符是:" + mostFrequentChar); ``` 以上代码会输出:出现次数最多字符是:d 这个函数能够找到给定字符串出现次数最多字符并将其返回。如果有多个字符出现次数相同且都是最多的,那么返回其任意一个即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值