2 回答
TA贡献1790条经验 获得超9个赞
当您的代码删除匹配项时,会将索引设置回零。问题是循环中的下一次迭代使其从索引 1 而不是 0 开始。因此您需要将其设置为 -1。实际上,使用 while 循环会更好。
下一个问题是你说下一个索引必须> 2。问题是索引是什么pp?这不是两个。您要确保索引不是同一个元素。
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]) != i) {
h++;
e.push(str.splice(0, str.lastIndexOf(str[i]) + 1));
i = -1;
} else {
str.splice(0, 1);
i = -1
}
}
return e
}
console.log(duplicateCount('ppaaaaccccccccgggiyddddhee'));
有一个 while 循环
function duplicateCount(text) {
const str = Array.from(text.toLowerCase()).sort();
var h = 0;
var e = [];
while (str.length) {
var lastIndex = str.lastIndexOf(str[0])
var removed = str.splice(0, lastIndex + 1);
if (lastIndex) {
h++;
e.push(removed);
}
}
return e
}
console.log(duplicateCount('ppaaaaccccccccgggiyddddhee'));
TA贡献1898条经验 获得超8个赞
认为使用正则表达式可以更好地做到这一点,并map()
分离出正则表达式匹配的每个字符串。然后,正如您所要求的,我们剩下一个字符串数组的数组。
(.)
- 第一个捕获组 - 匹配任何字符
\1
- 匹配与第一个捕获组相同的文本
+
- 匹配 1 次至无限次
const testString = "ppaaaaccccccccgggiyddddheep";
function getAllDuplicates(str) {
return str.split("") // split by character
.sort() // sort the array
.join("") // join back into sorted string
.match(/(.)\1+/g) // match repeated characters
.map(string => string.split("")); // use map to split each string in arr to get arr of strings
}
function getConsecutiveRepeating(str) {
return str.match(/(.)\1+/g) // match repeated characters
.map(string => string.split("")); // use map to split each string in arr to get arr of strings
}
console.log(getAllDuplicates(testString));
console.log(getConsecutiveRepeating(testString));
添加回答
举报