gpt4 book ai didi

Javascript 获取字符串中出现频率最高的所有字符

转载 作者:行者123 更新时间:2023-11-29 10:26:35 25 4
gpt4 key购买 nike

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

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

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

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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com