- 标签:哈希表、字符串、计数
- 难度:简单
描述:给定一个字符串
要求:返回出现次数最多,同时不在禁用列表中的单词。
说明:
- 题目保证至少有一个词不在禁用列表中,而且答案唯一。
- 禁用列表
$banned$ 中的单词用小写字母表示,不含标点符号。 - 段落
$paragraph$ 只包含字母、空格和下列标点符号!?',;.
- 段落中的单词不区分大小写。
-
$1 \le \text{段落长度} \le 1000$ 。 -
$0 \le \text{禁用单词个数} \le 100$ 。 -
$1 \le \text{禁用单词长度} \le 10$ 。 - 答案是唯一的,且都是小写字母(即使在
$paragraph$ 里是大写的,即使是一些特定的名词,答案都是小写的)。 - 不存在没有连字符或者带有连字符的单词。
- 单词里只包含字母,不会出现省略号或者其他标点符号。
示例:
- 示例 1:
输入:
paragraph = "Bob hit a ball, the hit BALL flew far after it was hit."
banned = ["hit"]
输出: "ball"
解释:
"hit" 出现了3次,但它是一个禁用的单词。
"ball" 出现了2次 (同时没有其他单词出现2次),所以它是段落里出现次数最多的,且不在禁用列表中的单词。
注意,所有这些单词在段落里不区分大小写,标点符号需要忽略(即使是紧挨着单词也忽略, 比如 "ball,"),
"hit"不是最终的答案,虽然它出现次数更多,但它在禁用单词列表中。
- 示例 2:
输入:
paragraph = "a."
banned = []
输出:"a"
- 将禁用词列表转为集合
$banned\underline{\hspace{0.5em}}set$ 。 - 遍历段落
$paragraph$ ,获取段落中的所有单词。 - 判断当前单词是否在禁用词集合中,如果不在禁用词集合中,则使用哈希表对该单词进行计数。
- 遍历完,找出哈希表中频率最大的单词,将该单词作为答案进行返回。
class Solution:
def mostCommonWord(self, paragraph: str, banned: List[str]) -> str:
banned_set = set(banned)
cnts = Counter()
word = ""
for ch in paragraph:
if ch.isalpha():
word += ch.lower()
else:
if word and word not in banned_set:
cnts[word] += 1
word = ""
if word and word not in banned_set:
cnts[word] += 1
max_cnt, ans = 0, ""
for word, cnt in cnts.items():
if cnt > max_cnt:
max_cnt = cnt
ans = word
return ans
-
时间复杂度:$O(n + m)$,其中
$n$ 为段落$paragraph$ 的长度,$m$ 是禁用词$banned$ 的长度。 - 空间复杂度:$O(n + m)$。