2 回答

TA貢獻(xiàn)1790條經(jīng)驗(yàn) 獲得超9個(gè)贊
當(dāng)您的代碼刪除匹配項(xiàng)時(shí),會(huì)將索引設(shè)置回零。問題是循環(huán)中的下一次迭代使其從索引 1 而不是 0 開始。因此您需要將其設(shè)置為 -1。實(shí)際上,使用 while 循環(huán)會(huì)更好。
下一個(gè)問題是你說下一個(gè)索引必須> 2。問題是索引是什么pp?這不是兩個(gè)。您要確保索引不是同一個(gè)元素。
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'));
有一個(gè) while 循環(huán)
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貢獻(xiàn)1898條經(jīng)驗(yàn) 獲得超8個(gè)贊
認(rèn)為使用正則表達(dá)式可以更好地做到這一點(diǎn),并map()
分離出正則表達(dá)式匹配的每個(gè)字符串。然后,正如您所要求的,我們剩下一個(gè)字符串?dāng)?shù)組的數(shù)組。
(.)
- 第一個(gè)捕獲組 - 匹配任何字符
\1
- 匹配與第一個(gè)捕獲組相同的文本
+
- 匹配 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));
添加回答
舉報(bào)