Skip to content

Commit b75639e

Browse files
authored
Create find-elements-in-a-contaminated-binary-tree.py
1 parent 925b8a6 commit b75639e

File tree

1 file changed

+34
-0
lines changed

1 file changed

+34
-0
lines changed
Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,34 @@
1+
# Time: O(n)
2+
# Space: O(h)
3+
4+
# Definition for a binary tree node.
5+
class TreeNode(object):
6+
def __init__(self, x):
7+
self.val = x
8+
self.left = None
9+
self.right = None
10+
11+
12+
class FindElements(object):
13+
14+
def __init__(self, root):
15+
"""
16+
:type root: TreeNode
17+
"""
18+
def dfs(node, v, lookup):
19+
if not node:
20+
return
21+
node.val = v
22+
lookup.add(v)
23+
dfs(node.left, 2*v+1, lookup)
24+
dfs(node.right, 2*v+2, lookup)
25+
26+
self.__lookup = set()
27+
dfs(root, 0, self.__lookup)
28+
29+
def find(self, target):
30+
"""
31+
:type target: int
32+
:rtype: bool
33+
"""
34+
return target in self.__lookup

0 commit comments

Comments
 (0)