Design a map that allows you to do the following:
Implement the MapSum class:
Example 1:
Input
["MapSum", "insert", "sum", "insert", "sum"]
[[], ["apple", 3], ["ap"], ["app", 2], ["ap"]]
Output
[null, null, 3, null, 5]
Explanation
MapSum mapSum = new MapSum();
mapSum.insert("apple", 3);
mapSum.sum("ap"); // return 3 (apple = 3)
mapSum.insert("app", 2);
mapSum.sum("ap"); // return 5 (apple + app = 3 + 2 = 5)
Constraints:
class TrieNode:
def __init__(self):
self.children = dict()
self.val = 0
class MapSum:
def __init__(self):
self.root = TrieNode()
def insert(self, key: str, val: int) -> None:
curr = self.root
for k in key:
if k not in curr.children:
curr.children[k] = TrieNode()
curr = curr.children[k]
curr.val = val
def sum(self, prefix: str) -> int:
answer = 0
curr = self.root
for c in prefix:
if c not in curr.children:
return 0
curr = curr.children[c]
q = collections.deque([curr])
while q:
curr = q.popleft()
answer += curr.val
for i in curr.children.values():
q.append(i)
return answer
# Your MapSum object will be instantiated and called as such:
# obj = MapSum()
# obj.insert(key,val)
# param_2 = obj.sum(prefix)