-
Notifications
You must be signed in to change notification settings - Fork 892
/
Copy pathproblem_284.py
53 lines (40 loc) · 1.07 KB
/
problem_284.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
47
48
49
50
51
52
53
class Node:
def __init__(self, val):
self.val = val
self.lev = None
self.l = None
self.r = None
self.p = None
def __repr__(self):
return "{} = (l={}, r={})".format(self.val, self.l, self.r)
def __hash__(self):
return hash(self.val)
def populate_level_map(node, level_map, parent=None, level=0):
if not node:
return
node.p = parent
node.lev = level
if level not in level_map:
level_map[level] = set()
level_map[level].add(node)
populate_level_map(node.l, level_map, node, level + 1)
populate_level_map(node.r, level_map, node, level + 1)
def get_cousins(root, node):
level_map = dict()
populate_level_map(root, level_map)
cousins = set([x for x in level_map[node.lev] if x.p != node.p])
return cousins
# Tests
a = Node(1)
b = Node(2)
c = Node(3)
d = Node(4)
e = Node(5)
f = Node(6)
a.l, a.r = b, c
b.l, b.r = d, e
c.r = f
assert get_cousins(a, d) == {f}
assert get_cousins(a, f) == {d, e}
assert get_cousins(a, a) == set()
assert get_cousins(a, c) == set()