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
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值