字母计数:return第一个单词重复字母最多的单词

Letter Count: return the first word with the greatest number of repeated letters

谁能帮我解决这个问题?这是一个字母计数挑战,您需要 return 具有最多重复字母的第一个单词,例如: Input = "Hello apple pie" Output = Hello

我尝试了很多不同的方法来调试我的代码并注意到字符串没有传递到 while 循环中,但我不知道为什么。谁能解释一下?

function LetterCount(str) { 
  str = str.split(" ");
  var index = 0;
  while(index >= str.length){
   for(var i = 0; i < str.length; i++){
      var str1 = str[i].split("").sort();
      for(var k = 0; k < str1.length; k++){
        
       if(index === 0 && str1[k] === str[k+1]){
          return str[i];
       }
       else if(index > 0 && str1[k] === str[k+1]){
          return str[i];
       }
      }
    }
    index++;
  }
  return -1;
}

Ewald 说你的 index 是 0,所以 while 循环不会执行。我认为如果将字母存储在字典中会更容易。

var niceDict = {};
//save letter and set initial value to zero
var letter = 'e';
niceDict[letter] = 0; // or niceDict['e'] = 0;
//incremente value
niceDict[letter]++;

这里还有一些正则表达式魔术可以实现它。 ;)

function LetterCount(str) {
    var parts = str.replace(/(\s+)|([A-Z]*?)([A-Z])(+)([A-Z]*)|([A-Z]+)/gi, ",,").split(',');
    var firstIndexOfMaxLetters, maxCount = 0;
    for (var i = 1; i < parts.length; i += 2)
        if (parts[i].length > maxCount)
            { maxCount = parts[i].length; firstIndexOfMaxLetters = i; }
    return firstIndexOfMaxLetters ? parts[firstIndexOfMaxLetters-1] : "";
}
LetterCount("Hi apPple pie")

输出:"apPple"

正则表达式将字符串变成这样:

["Hi", "", " ", "", "apPple", "pPp", " ", "", "pie", ""]

... 其中数组中的第二个项目是重复的字母(如果有的话,否则为空白),单词在它之前。 ;)