js--找字符串中出现最多的字符

在一个字符串中,如 ‘zhaochucichuzuiduodezifu‘,我们要找出出现最多的字符。本文章将详细说明方法思路。

先介绍两个string对象中的两个方法:indexOf()和charAt()方法

indexOf()方法介绍  返回某个指定的字符串值在字符串中首次出现的位置

语法 Object(string|array).indexOf(searchValue, fromIndex);
参数1  (必需)规定需检索的字符串值
参数2 (可选)规定在字符串中开始检索的位置(包括自身)。若省略,则从字符串的首字符开始检索
注1 对大小写敏感
注2 返回值是数字(索引),若检索不到,返回-1

charAt()方法介绍  返回某个指定位置的字符

语法 stringObject.charAt(index);
参数index (必需)字符串中某个位置的数字,即字符在字符串中的下标
下标从0开始,若超出0-string.length之外,返回一个空的字符串

先做一个小测试,找到字符串‘woainixiaoli‘中的每一个‘i‘出现的位置。

 1 <script>
 2     var arr = ‘woainixiaoli‘;
 3     var index = -1;   //定义变量index控制索引值
 4     //当查找不到a,即indexOf()的值为-1时,结束循环
 5     do {
 6         index = arr.indexOf("i", index + 1);  //使用第二个参数index+1,控制每一次查找都是从上一次查找到字符a的下一个索引位置开始
 7         if (index != -1) {    //可以找到字符i
 8            console.log(index);   //输出a的位置
 9         }
10     } while (index != -1);
11 </script>

以上代码运行后再控制台输出的是

进入正题,求字符串‘zhaochucichuzuiduodezifu‘最多的字符

方法一:用数组(存在缺点,当出现最多的字符不只一个时,只能找到一个)

 1 <script>
 2        var str = "zhaochucichuzuiduodezifu";
 3        var arr = [];//定义一个新数组
 4        //循环遍历字符串
 5        for (var i = 0, length = str.length; i < length; i++) {
 6            var index = -1;
 7            var j = 0;
 8            //找每一个字符
 9            do {
10                index = str.indexOf(str[i], index + 1);
11                if (index != -1) {
12                    j++;
13                }
14            }while (index != -1);
15            arr[j] = str[i];    //把字符串str中的字符赋给数组arr索引为j的数据,当多次循环后,会出现重复赋值的现象,                    //后赋值的会把之前的赋值覆盖掉,但不影响我们找出字符出现最多的那个
16        }
17        console.log(arr);
18        console.log("最多的字符是" + arr[arr.length - 1]);
19        console.log("次数是" + (arr.length - 1));
20 </script>

以上代码运行后再控制台输出的结果如下图:

  从输出的数组arr中也可以看出,此方法会把次数相同的字符覆盖,只能显示出一个。若有2个字符出现出现相同的最高次数,此方法只能得出一个。基于此,参照下一个用对象来解决的方法。

方法二:用对象(推荐使用)

<script>
    var str = "zhaochucichuzuiduodezifu";
    var o = {};
    for (var i = 0, length = str.length; i < length; 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);
    console.log("出现的次数是" + max);
</script>

以上代码运行后再控制台输出的结果如下图:

  此方法解决了方法一的问题,而且每一个字符我们都可以清楚的记录出现的次数,当有两个次数相同的字符时,可以在对象中清楚的看到。

  不过还是存在不足,不能直接把次数最高的字符同时输出,这还需要加额外的判断条件。完美的代码如下哈O(∩_∩)O

 1 <script>
 2     var str = "nininihaoa";
 3     var o = {};
 4     for (var i = 0, length = str.length; i < length; i++) {
 5         var char = str.charAt(i);
 6         if (o[char]) {
 7             o[char]++;  //次数加1
 8         } else {
 9             o[char] = 1;    //若第一次出现,次数记为1
10         }
11     }
12     console.log(o);   //输出的是完整的对象,记录着每一个字符及其出现的次数
13     //遍历对象,找到出现次数最多的字符的次数
14     var max = 0;
15     for (var key in o) {
16         if (max < o[key]) {
17             max = o[key];   //max始终储存次数最大的那个
18         }
19     }
20     for (var key in o) {
21         if (o[key] == max) {
22             //console.log(key);
23             console.log("最多的字符是" + key);
24             console.log("出现的次数是" + max);
25         }
26     }
27 </script>

结果如下:

时间: 2024-10-05 11:09:28

js--找字符串中出现最多的字符的相关文章

数组去重及排序/0~10随机数字/字符串中出现最多的字符及次数

数组去重及排序: var arr = [1,5,1,2,6,8,1,81,9,0]; for(var i=0;i<arr.length;i++){ for(var j=i+1;j<arr.length;j++){ if(arr[i] == arr[j]){ arr.splice(j,1); j--; } } } arr.sort(function(a,b){ return a-b; // 从小到大排序 }) alert(arr); // 0,1,2,5,6,8,9,81 arr.sort(fu

用js识别字符串中的英文字母字符和非字符(汉字)

前不久去阿里的在线笔试,最后一道题可算是难倒了我,题目大概是这样的:用原生的js实现字符串中的英文字母字符和汉字的识别,汉字按照两个单位计算,英文和字符按照一个单位计算,乍一想真不知道有什么好办法,以前写c代码太多,就用c代码对ascii的办法来,笔试结束字符才知道,js是很高大上的玩意儿,这招行不通.在这里我介绍一种很简单很靠谱的方法,用unicode字符集的办法来解决. 首先脑补一下小知识:unicode字符集数字0 - 128是英文字母字符(半角)的范畴,在这以外是其他字符(全角),用js

js替换字符串中所有指定的字符

第一次发现JavaScript中replace() 方法如果直接用str.replace("-","!") 只会替换第一个匹配的字符. 而str.replace(/\-/g,"!")则可以全部替换掉匹配的字符(g为全局标志). replace() The replace() method returns the string that results when you replace text matching its first argumen

JS判断字符串中是否存在某个字符

用String类中的indexOf函数,例如:String str="we find out sth";if(str.indexOf("o")==-1){ //等于-1表示这个字符串中没有o这个字符//do something}else{//do something}

查找字符串中出现最多的字符

方法一:利用js的split和join方法 1 function foo(str){ 2 var max = 0; 3 var char = []; // 存放出现次数最多的字符 4 while(str){ 5 var head = str.charAt(0); 6 var arr = str.split(head); 7 var num = str.length - arr.join('').length; 8 if(num > max){ 9 max = num; 10 char.lengt

求一个字符串中出现最多的字符和次数

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script> var str = "zhaochucichuzuiduodezifu"; var json = {}; for (var i = 0; i < str.length;

找出给定字符串中出现最多的字符和次数

public static void findMaxCountChar(String str) { if (str == null || str == "") return; Map<String, Integer> map = new HashMap<String, Integer>(); int maxCount = 0; String maxCountStr = ""; List<String> list = new Arr

[java] 找出字符串中出现最多的字符和出现的次数

逛园子看到一童鞋做的华为上机题目,写来好长的代码,懒得看,感觉不可能这么难,于是动手敲了下. import java.util.Scanner; public class StringTest { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub Scanner scanner = new Scanner(System.in); String A = s

输入一排字符串,然后统计字符串中出现最多的字符

static void Main(string[] args) { string str = "abcabcqwe"; if (str.Length > 0) { //把字符串进行分割 char[] strChar = str.ToCharArray(); //把字符先分组后排序 var c = strChar.GroupBy(m => m).OrderByDescending(m => m.Count()).ToList(); var first = strChar