leetcode 算法题884 (简单231) 两句话中的不常见单词

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/FYuu95100/article/details/102724285

leetcode 算法题884 (简单231) 两句话中的不常见单词

  • 题目介绍
给定两个句子 A 和 B 。 
(句子是一串由空格分隔的单词。每个单词仅由小写字母组成。)
如果一个单词在其中一个句子中只出现一次,
在另一个句子中却没有出现,
那么这个单词就是不常见的。
返回所有不常用单词的列表。
您可以按任何顺序返回列表。
  • 示例

输入:A = “this apple is sweet”, B = “this apple is sour”
输出:[“sweet”,“sour”]

输入:A = “apple apple”, B = “banana”
输出:[“banana”]

  • 提示

0 <= A.length <= 200
0 <= B.length <= 200
A 和 B 都只包含空格和小写字母。

  • 解法一
/**
 * @param {string} A
 * @param {string} B
 * @return {string[]}
 */
var uncommonFromSentences = function(A, B) {
    let map = {}, temp = [];
    setMap(A, map);
    setMap(B, map);
    for(let key in map) {
      if(map[key] === 1) {
        temp.push(key);
      }
    }
    return temp;
};

const setMap = (str, map) => {
  str.split(' ').forEach(s => {
    if(map[s]) {
      map[s]++;
    } else {
      map[s] = 1;
    }
  })
}

执行用时 : 60 ms, 在所有 JavaScript 提交中击败了94.85%的用户

内存消耗 : 34.4 MB, 在所有 JavaScript 提交中击败了29.27%的用户

猜你喜欢

转载自blog.csdn.net/FYuu95100/article/details/102724285