884. 两句话中的不常见单词
句子 是一串由空格分隔的单词。每个 单词 仅由小写字母组成。
如果某个单词在其中一个句子中恰好出现一次,在另一个句子中却 没有出现 ,那么这个单词就是 不常见的 。
给你两个 句子 s1 和 s2 ,返回所有 不常用单词 的列表。返回列表中单词可以按 任意顺序 组织。
示例 1:
输入:s1 = “this apple is sweet”, s2 = “this apple is sour”
输出:[“sweet”,“sour”]
示例 2:
输入:s1 = “apple apple”, s2 = “banana”
输出:[“banana”]
提示:
1 <= s1.length, s2.length <= 200
s1 和 s2 由小写英文字母和空格组成
s1 和 s2 都不含前导或尾随空格
s1 和 s2 中的所有单词间均由单个空格分隔
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/uncommon-words-from-two-sentences
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
分析
今天的每日一题。
先对句子按照空格分割,用哈希表存储两个句子的单词,哈希表的两个参数分别为String和Integer,第一个记录单词,第二个记录出现次数,遍历哈希表将次数为1的单词存入集合中,最后把集合转换为数组返回。
题解(Java)
class Solution {
public String[] uncommonFromSentences(String s1, String s2) {
String[] arr1 = s1.split(" ");
String[] arr2 = s2.split(" ");
List<String> ans = new ArrayList<>();
Map<String, Integer> map = new HashMap<>();
for (String s : arr1) {
map.put(s, map.getOrDefault(s, 0) + 1);
}
for (String s : arr2) {
map.put(s, map.getOrDefault(s, 0) + 1);
}
for (Map.Entry<String, Integer> entry : map.entrySet()) {
if (entry.getValue() == 1) ans.add(entry.getKey());
}
return ans.toArray(new String[0]);
}
}