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));
添加回答
舉報