-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathLesson8_Trees.py
114 lines (97 loc) · 3.29 KB
/
Lesson8_Trees.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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
"""Memory manager code"""
def initmemory(maxn):
memory = []
for i in range(maxn):
memory.append([0, i+1, 0])
return [memory, 0]
def newnode(memstruct):
memory, firstfree = memstruct
memstruct[1] = memory[firstfree][1]
return firstfree
def delnode(memstruct, index):
memory, firstfree = memstruct
memory[index][1] = firstfree
memstruct[1] = index
"""Binary tree - search realization"""
def find(memstruct, root, x):
key = memstruct[0][root][0]
if x == key:
return root
elif x < key:
left = memstruct[0][root][1]
if left == -1:
return -1
else:
return find(memstruct, left, x)
elif x > key:
right = memstruct[0][root][2]
if right == - 1:
return -1
else:
return find(memstruct, right, x)
"""Binary tree - add realization"""
def createandfillnode(memstruct, key):
# index = newnode(memstruct)
memstruct[0][index][0] = key
memstruct[0][index][1] = -1
memstruct[0][index][2] = -1
return index
def add(memstruct, root, x):
key = memstruct[0][root][0]
if x < key:
left = memstruct[0][root][1]
if left == -1:
memstruct[0][root][1] = createandfillnode(memstruct, x)
else:
add(memstruct, left, x)
elif x > key:
right = memstruct[0][root][2]
if right == -1:
memstruct[0][root][2] = createandfillnode(memstruct, x)
else:
add(memstruct, right, x)
memstruct = initmemory(20)
root = createandfillnode(memstruct, 8)
add(memstruct, root, 10)
add(memstruct, root, 9)
add(memstruct, root, 14)
add(memstruct, root, 13)
add(memstruct, root, 3)
add(memstruct, root, 1)
add(memstruct, root, 6)
add(memstruct, root, 4)
add(memstruct, root, 7)
"""Tree in Python"""
#[key, [left], [right]]
#[5, [2, None,[3, None, None]],[7, None, [8, None, None]]]
"""Create a tree and searching through the tree"""
"""Having a serialized tree description, like DUDUUUDDU, we need to make a code for all of the leaves"""
"""D - means that we go to the leftmost unvisited child (we suppose that there are two child - 2 or there aren't any of them - 0)"""
"""U - means that we go up till we go from the right child. If we came to the top from the left child - we go directly to the right child"""
def maketree(serialized):
tree = {'left': None,'right': None, 'up': None, 'type': 'root'}
nownode = tree
for sym in serialized:
if sym == 'D':
newnode = {'left': None, 'right': None, 'up' : nownode, 'type': 'left'}
nownode['left'] = newnode
nownode = newnode
elif sym == 'U':
while nownode['type'] == 'right':
nownode = nownode['up']
nownode = nownode['up']
newnode = {'left': None, 'right': None, 'up': nownode, 'type': 'right'}
nownode['right'] = newnode
nownode = newnode
return tree
print(maketree("DDUUDU"))
def traverse(root, prefix):
if root['left'] is None and root['right'] is None:
return["".join(prefix)]
prefix.append('0')
ans = traverse(root['left'], prefix)
prefix.pop()
prefix.append('1')
ans.extend(traverse(root['right'], prefix))
prefix.pop()
return ans