【问题标题】:Test word against array for anagrams - Javascript针对字谜的数组测试单词 - Javascript
【发布时间】:2020-07-09 10:21:58
【问题描述】:

到目前为止.. 我有这个:

function anagrams(word, words) {
  for(let i = 0; i <= words.length; i++){
  const aCharMap = buildCharMap(word);
  const bCharMap = buildCharMap(words[i]);

  if(Object.keys(aCharMap).length !== Object.keys(bCharMap).length) {
    words.pop(words[i])
  }
  for (let char in aCharMap) {
    if (aCharMap[char] !== bCharMap[char]) {
    words.pop(words[i]);
    }
  }
  console.log(word);
  console.log(words);
  }
}

  function buildCharMap(str) {
  const charMap = {};
  for (let char of str.replace(/[^\w]/g, '').toLowerCase()) {
  charMap[char] = charMap[char] + 1 || 1;
  }
  return charMap;
}

如果您通读代码,手头的问题很明显,但这里是

编写一个函数,从一个列表中找出一个单词的所有字谜。您将获得两个输入一个单词和一个带有单词的数组。如果没有,您应该返回所有字谜的数组或空数组。例如:

anagrams('abba', ['aabb', 'abcd', 'bbaa', 'dada']) =&gt; ['aabb', 'bbaa']

anagrams('racer', ['crazer', 'carer', 'racar', 'caers', 'racer']) =&gt; ['carer', 'racer']

anagrams('laser', ['lazing', 'lazy', 'lacer']) =&gt; []

【问题讨论】:

    标签: javascript arrays testing anagram


    【解决方案1】:

    pop 是按照你的方式使用的吗?

    您也可以这样做:

    function anagrams(word, words) {
    let result = [];
    const aCharMap = buildCharMap(word);
    
    // you also had a off-by-one error in loop 
    for (let i = 0; i < words.length; i++) {
        const bCharMap = buildCharMap(words[i]);
    
        let isAnagram = (a, b) => {
            if (Object.keys(a).length !== Object.keys(b).length) return false;
            for (let char in a) {
                if (aCharMap[char] !== b[char]) {
                    return false
                }
            }
            return true;
        }
    
        if (isAnagram(aCharMap, bCharMap)) result.push(words[i])
    
    }
    
    function buildCharMap(str) {
        const charMap = {};
        for (let char of str.replace(/[^\w]/g, '').toLowerCase()) {
            charMap[char] = charMap[char] + 1 || 1;
        }
        return charMap;
    }
    
    return result
    }
    
    console.log(anagrams("test", ["estt", "ttee", "tset"]))

    【讨论】:

    • pop是数组上的js方法
    • 这很棒,是的,我不应该使用这些语法!我很高兴你按照我的想法完成了它,但我不太清楚如何。我仍在学习这些 lamdas 和使用布尔值后返回的语法规则。我来自沉重的 Java 背景
    猜你喜欢
    • 1970-01-01
    • 2010-09-28
    • 2011-02-07
    • 2015-12-04
    • 2016-01-12
    • 2021-10-16
    • 2020-09-25
    • 2023-03-09
    • 1970-01-01
    相关资源
    最近更新 更多