-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTop_view_of_tree.py
62 lines (54 loc) · 1.58 KB
/
Top_view_of_tree.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
54
55
56
57
58
59
60
61
62
#Printing the top view elements of a tree
class node:
def __init__(self,data):
self.value=data
self.left=None
self.right=None
class node_data:
def __init__(self,node,HKey):
self.node=node
self.HKey=HKey
def topview(root):
temp=node_data(root,0)
Q=[temp]
Q.append(None)
key_Dict={}
while len(Q)!=0:
curr=Q.pop(0)
if curr==None:
if len(Q)==0:
break
else:
Q.append(None)
else:
if curr.HKey not in key_Dict.keys():
key_Dict[curr.HKey]=curr.node.value
if curr.node.left!=None:
temp=node_data(curr.node.left,curr.HKey-1)
Q.append(temp)
if curr.node.right!=None:
temp=node_data(curr.node.right,curr.HKey+1)
Q.append(temp)
for i in sorted(key_Dict):
print(key_Dict[i],end=' ')
print(key_Dict)
if __name__=="__main__":
root=node(1)
root.left=node(2)
root.right=node(3)
root.left.left=node(4)
root.left.right=node(5)
root.right.left=node(6)
root.right.right=node(7)
root.left.right.left=node(9)
root.left.right.right=node(10)
root.right.right.right=node(11)
root.left.right.left.left=node(12)
root.left.right.left.right=node(13)
print("top view elements")
topview(root)
"""
OUTPUT:
top view elements
4 2 1 3 7 11 {0: 1, -1: 2, 1: 3, -2: 4, 2: 7, 3: 11}
"""