第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

計(jì)算錯(cuò)誤的唯一重復(fù)項(xiàng)

計(jì)算錯(cuò)誤的唯一重復(fù)項(xiàng)

素胚勾勒不出你 2023-07-06 10:20:41
我遇到了這個(gè)挑戰(zhàn),您必須計(jì)算提供的字符串中有多少個(gè)重復(fù)項(xiàng)。我想出了這段代碼,如果有重復(fù)的字符串,應(yīng)該對(duì)字符串進(jìn)行排序,拼接它們并將它們計(jì)為總數(shù)+1。如果這封信不是重復(fù)的 -> 只需將它們拼接起來,這樣我就可以繼續(xù)前進(jìn)。代碼怎么了?我想要的不是挑戰(zhàn)的答案,而是了解我哪里出錯(cuò)了。為什么僅當(dāng)有 4 個(gè)以上相同字母時(shí)代碼才會(huì)注冊(cè)重復(fù)項(xiàng)?這是代碼,請(qǐng)注意,我僅使用 來var e查看數(shù)組的哪一部分被拼接。預(yù)期輸出:[[p, p], [a, a, a, a], [c, c, c, c, c, c, c, c], [d, d, d, d], [g, g, g], [e, e]]如果同一字符切片出現(xiàn) 2 次以上,則該字符切片會(huì)重復(fù)出現(xiàn)并將它們放入新數(shù)組中。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'));
查看完整描述

2 回答

?
富國(guó)滬深

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'));


查看完整回答
反對(duì) 回復(fù) 2023-07-06
?
汪汪一只貓

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));


查看完整回答
反對(duì) 回復(fù) 2023-07-06
  • 2 回答
  • 0 關(guān)注
  • 127 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)