Javascript 获取字符串中所有最常见的字符

标签 javascript

我需要帮助了解如何不仅仅是获取一个而是其他字符串中最常见的字符/字母。

我的代码仅适用于获取常见字符之一。

但是当多个字符同样常见时,仅返回一个。如果两个字符很常见,我希望它返回两个字符。

const x = mostCommonCharacter("abbbcddefffg");
console.log(x); // result is *b* 

如果bf最常见,我想返回bf

  function mostCommonCharacter(str) {
  const charHolder = {}; // { a: 1, b: 3, c: 1, d: 2, e: 1, f: 3, g: 1 }

  str
    .toLowerCase()
    .split("")
    .forEach(char => {
      if (char != " ") {
        if (charHolder[char] == null) {
          charHolder[char] = 1;
        } else {
          charHolder[char] += 1;
        }
      }
    });
  let highest_num = 0;
  let letter = "";
  for (const key in charHolder) {
    if (charHolder[key] > highest_num) {
      highest_num = charHolder[key];
      letter = key;
    }
  }
  return letter;
}

但它只返回一个最常见的字符,即“b

我需要的是它返回“b”和“f”,因为它们都是最常见的。不仅仅是b有办法做到这一点吗?

最佳答案

获取highest_num,然后再次迭代对象并获取计数等于highest_num的那些字母

function mostCommonCharacter(str) {
  const charHolder = {}; // { a: 1, b: 3, c: 1, d: 2, e: 1, f: 3, g: 1 }

  str
    .toLowerCase()
    .split("")
    .forEach(char => {
      if (char != " ") {
        if (charHolder[char] == null) {
          charHolder[char] = 1;
        } else {
          charHolder[char] += 1;
        }
      }
    });
  let highest_num = 0;
  for (const key in charHolder) {
    if (charHolder[key] > highest_num) {
      highest_num = charHolder[key];
    }
  }
  let res = '';
  for(let k in charHolder){
    if(charHolder[k] === highest_num){
      res += k;
    }
  }
  return res;
}

console.log(mostCommonCharacter("abbbcddefffg"))

可以使用reduce()Math.max获得较短版本的代码

function mostCommonCharacter(str) {
  const charHolder = str
                      .toLowerCase()
                      .split('')
                      .reduce((ac,a) => (ac[a] = ac[a] + 1 || 1, ac), {});

  let max = Math.max(...Object.values(charHolder));

  return Object.entries(charHolder).reduce((ac,[k,v]) =>v === max ? ac + k : ac, '');
  
}

console.log(mostCommonCharacter("abbbcddefffg"))

关于Javascript 获取字符串中所有最常见的字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57678798/

相关文章:

javascript - Cordova InAppBrowser 不适用于 iOS

javascript - 用于在网页中编写脚本的 Firefox 扩展

javascript - 如何计算圈复杂度?

c# - 使用 COM-Interop 将数组从 JS 返回到 C#

javascript - Jquery 使用动态值验证 Max 方法?

javascript - Webgl Sprite 渲染,alpha 混合白边

javascript - Seleniumwebdirver 与 Java 登录身份验证失败;传递正确的凭据

javascript - 过滤 Axios 响应

javascript - 具有颜色叠加语法的动态背景图像 - Angular

javascript - 按以逗号分隔的关键字突出显示文本