-
Notifications
You must be signed in to change notification settings - Fork 97
/
Copy path232.py
46 lines (33 loc) · 1.14 KB
/
232.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
"""
Problem:
Implement a PrefixMapSum class with the following methods:
insert(key: str, value: int): Set a given key's value in the map. If the key already
exists, overwrite the value.
sum(prefix: str): Return the sum of all values of keys that begin with a given prefix.
For example, you should be able to run the following code:
>>> mapsum.insert("columnar", 3)
>>> assert mapsum.sum("col") == 3
>>> mapsum.insert("column", 2)
>>> assert mapsum.sum("col") == 5
"""
from DataStructures.Trie import Trie
class PrefixMapSum:
def __init__(self) -> None:
self.trie = Trie()
self.hash_map = {}
def insert(self, key: str, value: int) -> None:
if key not in self.hash_map:
self.trie.add(key)
self.hash_map[key] = value
def sum(self, prefix: str) -> int:
words = self.trie.get_suggestions(prefix)
result = 0
for word in words:
result += self.hash_map[word]
return result
if __name__ == "__main__":
mapsum = PrefixMapSum()
mapsum.insert("columnar", 3)
assert mapsum.sum("col") == 3
mapsum.insert("column", 2)
assert mapsum.sum("col") == 5