亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

計算錯誤的唯一重復項

計算錯誤的唯一重復項

素胚勾勒不出你 2023-07-06 10:20:41
我遇到了這個挑戰,您必須計算提供的字符串中有多少個重復項。我想出了這段代碼,如果有重復的字符串,應該對字符串進行排序,拼接它們并將它們計為總數+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'));
查看完整描述

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


查看完整回答
反對 回復 2023-07-06
?
汪汪一只貓

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


查看完整回答
反對 回復 2023-07-06
  • 2 回答
  • 0 關注
  • 140 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號