我需要帮助了解如何不仅仅是获取一个而是其他字符串中最常见的字符/字母。
我的代码仅适用于获取常见字符之一。
但是当多个字符同样常见时,仅返回一个。如果两个字符很常见,我希望它返回两个字符。
const x = mostCommonCharacter("abbbcddefffg");
console.log(x); // result is *b*
如果b和f最常见,我想返回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/