我遇到了这个挑战,您必须计算提供的字符串中有多少个重复项。
我想出了这段代码,如果有重复的字符串,应该对字符串进行排序,拼接它们并将它们计为总数+1。如果这封信不是重复的 -> 只需将它们拼接起来,这样我就可以继续前进。
代码怎么了?我想要的不是挑战的答案,而是了解我哪里出错了。为什么仅当有 4 个以上相同字母时代码才会注册重复项?
这是代码,请注意,我仅使用 来var e
查看数组的哪一部分被拼接。
预期输出:
[[p, p], [a, a, a, a], [c, c, c, c, c, c, c, c], [d, d, d, d], [g, g, g], [e, e]]
如果同一字符切片出现 2 次以上,则该字符切片会重复出现并将它们放入新数组中。
function duplicateCount(text) {
const str = Array.from(text.toLowerCase()).sort();
var h = 0;
var e = [];
for (let i = 0; i < str.length; i++) {
if (str.lastIndexOf(str[i]) > 2) {
h++;
e.push(str.splice(0, str.lastIndexOf(str[i]) + 1));
i = 0;
} else {
str.splice(0, 1);
i = 0
}
}
return e
}
console.log(duplicateCount('ppaaaaccccccccgggiyddddhee'));
富国沪深
汪汪一只猫
相关分类