zoukankan      html  css  js  c++  java
  • 找出字符串中出现次数最多的字符。

    一、循环obj

    复制代码
    let testStr = 'asdasddsfdsfadsfdghdadsdfdgdasd';
            function getMax(str) {
                let obj = {};
                for(let i in str) {
                    if(obj[str[i]]) {
                        obj[str[i]]++;
                    }else{
                        obj[str[i]] = 1;
                    }
                }
                let keys = Object.keys(obj); // 获取对象中所有key的值返回数组
                let values = Object.values(obj); // 获取所有value返回数组
                let maxVal = Math.max(...values);// Math.max可以找出传入参数的最大值,如:Math.max(1,2);这里可使用es6中的解构,
            也可以使用Math.max.apply(Math,values)可认为是apply(Math.max, arr)
            然后,arr是一个参数列表,对于max方法,其参数是若干个数,即Math.max(a, b, c, d, ...) console.log(keys[values.indexOf(maxVal)],maxVal); } getMax(testStr); // obj值:{a: 5, s: 7, d: 12, f: 4, g: 2, h: 1, s: 7,}




    // 很牛的reduce方法

    var testStr = 'asdasddsfdsfadsfdghdadsdfdgdasd';
    var testArray = testStr.split('');
    var a = testArray.reduce(function(prev,next){
      if(next in prev) {
        prev[next]++;
      }else {
        prev[next] = 1;
      }
      return prev
    },{})
    console.log(a)

     
    复制代码
    keys[values.indexOf(maxVal)] => value里面最大的数字的位置,最大数字位置对应的key。
    maxVal最大的数,也就是出现做多的次数。
    str[i]是对应字符串中的第i个字符,
    obj[str[i]] 就是对应的每个字母
    for循环就是把里面出现了的字母作为obj这个对象的key,然后循环的时候判断obj里面有没有以str[i]为key的对象,如有,就把它的value加一,说明这个字母在obj中出现的次数多了一次;刚开始i是键名,str[i]是键值,用这个键值再做obj的键名,然后赋值,或累加

    eg:
    obj[str[i]] = 1;  =>  var obj={};obj.aa = 1;console.log(obj)

    二、正则
    复制代码
    let stringMax = (str) => {
                str = str.split('').sort().join('');
                var s = str.match(/(w+)(1)/g);
                if(s === null) {
                    return str[0];
                }
                s = s.map(e => e=e+e[0]);
                var out = s.sort((a,b) =>b.length - a.length);
                console.log(out[0][0],out[0].length);
            };
            stringMax(testStr)
    复制代码
     
     
     
  • 相关阅读:
    两个半成品的ORM
    Mayberry小镇的管理 | 三种截然不同的领导风格 3M
    敏捷的目的(方向)错了以后……
    Error:java: Compilation failed: internal java compiler error
    java: -source 1.5 中不支持 diamond 运算符 (请使用 -source 7 或更高版本以启用 diamond 运算符)
    看mybatis日志模块时涉及的动态代理
    看的顺眼的却Destination Unreachable
    如何下载钉钉回放视频
    不想学习时看一看会有帮助的,“但行好事,莫问前程”
    守护线程
  • 原文地址:https://www.cnblogs.com/baixiaoxiao/p/10631031.html
Copyright © 2011-2022 走看看