Most Common Word - Problem
Given a string paragraph and a string array of the banned words, return the most frequent word that is not banned.
It is guaranteed there is at least one word that is not banned, and that the answer is unique.
The words in paragraph are case-insensitive and the answer should be returned in lowercase.
Note: Words cannot contain punctuation symbols.
Input & Output
Example 1 — Basic Case
$
Input:
paragraph = "Bob hit a ball, the hit BALL flew far after it was hit.", banned = ["hit"]
›
Output:
"ball"
💡 Note:
"hit" appears 3 times but is banned. "ball" appears 2 times (case-insensitive: "ball", "BALL") and is not banned, making it the most frequent valid word.
Example 2 — Multiple Banned Words
$
Input:
paragraph = "a, a, a, a, b,b,b,c, c", banned = ["a"]
›
Output:
"b"
💡 Note:
"a" appears 4 times but is banned. "b" appears 3 times and "c" appears 2 times. "b" is the most frequent non-banned word.
Example 3 — Case Insensitive
$
Input:
paragraph = "Bob bob BOB", banned = []
›
Output:
"bob"
💡 Note:
"Bob", "bob", and "BOB" are the same word (case-insensitive). "bob" appears 3 times and no words are banned.
Constraints
- 1 ≤ paragraph.length ≤ 1000
- paragraph consists of English letters, space ' ', or one of the symbols: "!?',;."
- 0 ≤ banned.length ≤ 100
- 1 ≤ banned[i].length ≤ 10
- banned[i] consists of only lowercase English letters
Visualization
Tap to expand
Understanding the Visualization
1
Input
Raw paragraph with punctuation and banned words list
2
Process
Clean text, extract words, count frequencies, filter banned
3
Output
Most frequent word that's not in banned list
Key Takeaway
🎯 Key Insight: Use hash maps for efficient frequency counting and banned word filtering in a single pass
💡
Explanation
AI Ready
💡 Suggestion
Tab
to accept
Esc
to dismiss
// Output will appear here after running code