-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfind-mode-in-binary-search-tree_501.py
46 lines (31 loc) · 1.31 KB
/
find-mode-in-binary-search-tree_501.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
# Given the root of a binary search tree (BST) with duplicates,
# return all the mode(s) (i.e., the most frequently occurred element) in it.
# If the tree has more than one mode, return them in any order.
# Assume a BST is defined as follows:
# The left subtree of a node contains only nodes with keys less than or equal to the node's key.
# The right subtree of a node contains only nodes with keys greater than or equal to the node's key.
# Both the left and right subtrees must also be binary search trees.
# Example 1:
# Input: root = [1,null,2,2]
# Output: [2]
# Example 2:
# Input: root = [0]
# Output: [0]
# ---------------------------------------Runtime 1565 ms Beats 5.4% Memory 20.7 MB Beats 56.6%---------------------------------------
from typing import List, Optional
class TreeNode:
def __init__(self, val=0, left=None, right=None):
self.val = val
self.left = left
self.right = right
class Solution:
def findMode(self, root: Optional[TreeNode]) -> List[int]:
hash_map = dict()
def bst(node):
if node:
val = node.val
hash_map[val] = hash_map.get(val, 0) + 1
bst(node.left)
bst(node.right)
bst(root)
return [k for k, v in hash_map.items() if v == max(hash_map.values())]