-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathbtree.py
85 lines (68 loc) · 1.64 KB
/
btree.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
#!/usr/bin/env python
# encoding: utf-8
# author: Lock
# time: 2018/1/24 00:38
class BTree:
def __init__(self, value):
self.left = None
self.data = value
self.right = None
def insertLeft(self, value):
self.left = BTree(value)
return self.left
def insertRight(self, value):
self.right = BTree(value)
return self.right
def show(self):
print self.data,
def preorder(node):
if node.data:
node.show()
if node.left:
preorder(node.left)
if node.right:
preorder(node.right)
def inorder(node):
if node.data:
if node.left:
inorder(node.left)
node.show()
if node.right:
inorder(node.right)
def postorder(node):
if node.data:
if node.left:
postorder(node.left)
if node.right:
postorder(node.right)
node.show()
def layerorder(node):
stack = [node]
while len(stack):
node = stack.pop(0)
if node.data:
node.show()
if node.left:
stack.append(node.left)
if node.right:
stack.append(node.right)
if __name__ == "__main__":
Root = BTree("root")
A = Root.insertLeft("A")
C = A.insertLeft("C")
D = C.insertRight("D")
F = D.insertLeft("F")
G = D.insertRight("G")
B = Root.insertRight("B")
E = B.insertRight("E")
print "前序遍历:",
preorder(Root)
print ""
print "中序遍历:",
inorder(Root)
print ""
print "后序遍历:",
postorder(Root)
print ""
print "层序遍历:",
layerorder(Root)