aboutsummaryrefslogtreecommitdiff
path: root/challenge-255/sgreen/python/ch-2.py
diff options
context:
space:
mode:
authorSimon Green <mail@simon.green>2024-02-11 17:05:04 +1100
committerSimon Green <mail@simon.green>2024-02-11 17:05:04 +1100
commitd4525399d41dd57f21bc11a67ceb63bdb16bc146 (patch)
tree6ef501f14ad4ccb10ac9d95d9f9d7f2a0809e679 /challenge-255/sgreen/python/ch-2.py
parent34fa48cf4b02c81fd6ed544498bde068aca981a2 (diff)
downloadperlweeklychallenge-club-d4525399d41dd57f21bc11a67ceb63bdb16bc146.tar.gz
perlweeklychallenge-club-d4525399d41dd57f21bc11a67ceb63bdb16bc146.tar.bz2
perlweeklychallenge-club-d4525399d41dd57f21bc11a67ceb63bdb16bc146.zip
Simon's solution to challenge 255
Diffstat (limited to 'challenge-255/sgreen/python/ch-2.py')
-rwxr-xr-xchallenge-255/sgreen/python/ch-2.py38
1 files changed, 38 insertions, 0 deletions
diff --git a/challenge-255/sgreen/python/ch-2.py b/challenge-255/sgreen/python/ch-2.py
new file mode 100755
index 0000000000..1a04788c22
--- /dev/null
+++ b/challenge-255/sgreen/python/ch-2.py
@@ -0,0 +1,38 @@
+#!/usr/bin/env python3
+
+import re
+import sys
+
+
+def most_frequent_word(p: str, b: str) -> str:
+ """Find the most frequent word that isn't banned
+
+ Args:
+ p (str): The paragraph
+ b (str): The banned word
+
+ Returns:
+ str: The most frequent word
+ """
+
+ # Calculate the frequency of all the words
+ freq = {}
+ for word in re.findall(r"\w+(?:'\w+)?", p.lower()):
+ freq[word] = freq.get(word, 0) + 1
+
+ # Remove the bad word (if it exists)
+ freq.pop(b, None)
+
+ # Find the maximum occurrence of any word, and the word that has this
+ max_count = max(freq.values())
+ words = [k for k in freq if freq[k] == max_count]
+ return words[0]
+
+
+def main():
+ result = most_frequent_word(sys.argv[1], sys.argv[2])
+ print(result)
+
+
+if __name__ == '__main__':
+ main()