mirror of
https://github.com/autistic-symposium/master-algorithms-py.git
synced 2025-04-30 12:46:11 -04:00
165 lines
3.6 KiB
Python
165 lines
3.6 KiB
Python
#!/usr/bin/python
|
|
|
|
__author__ = "bt3"
|
|
|
|
from collections import deque
|
|
|
|
class Node(object):
|
|
|
|
def __init__(self, item=None):
|
|
|
|
self.item = item
|
|
self.left = None
|
|
self.right = None
|
|
|
|
|
|
def _add(self, value):
|
|
new_node = Node(value)
|
|
if not self.item:
|
|
self.item = new_node
|
|
else:
|
|
if value > self.item:
|
|
self.right = self.right and self.right._add(value) or new_node
|
|
elif value < self.item:
|
|
self.left = self.left and self.left._add(value) or new_node
|
|
else:
|
|
print("BSTs do not support repeated items.")
|
|
return self
|
|
|
|
|
|
def _search(self, value):
|
|
if self.item == value:
|
|
return True
|
|
elif self.left and value < self.item:
|
|
return self.left._search(value)
|
|
elif self.right and value > self.item:
|
|
return self.right._search(value)
|
|
else:
|
|
return False
|
|
|
|
|
|
def _isLeaf(self):
|
|
return not self.right and not self.left
|
|
|
|
|
|
def _printPreorder(self):
|
|
print self.item
|
|
|
|
if self.left:
|
|
self.left._printPreorder()
|
|
|
|
if self.right:
|
|
self.right._printPreorder()
|
|
|
|
|
|
def _preorder_array(self):
|
|
nodes = []
|
|
if self.item:
|
|
nodes.append(self.item)
|
|
if self.left:
|
|
nodes.extend(self.left._preorder_array())
|
|
if self.right:
|
|
nodes.extend(self.right._preorder_array())
|
|
return nodes
|
|
|
|
|
|
|
|
class BST(object):
|
|
|
|
def __init__(self):
|
|
self.root = None
|
|
|
|
def add(self, value):
|
|
if not self.root:
|
|
self.root = Node(value)
|
|
else:
|
|
self.root._add(value)
|
|
|
|
def printPreorder(self):
|
|
if self.root:
|
|
self.root._printPreorder()
|
|
|
|
def search(self, value):
|
|
if self.root:
|
|
return self.root._search(value)
|
|
|
|
def preorder_array(self):
|
|
if self.root:
|
|
return self.root._preorder_array()
|
|
else:
|
|
return 'Tree is empty.'
|
|
|
|
|
|
|
|
|
|
def BFT(tree):
|
|
current = tree.root
|
|
nodes = []
|
|
queue = deque()
|
|
queue.append(current)
|
|
|
|
while queue:
|
|
current = queue.popleft()
|
|
nodes.append(current.item)
|
|
if current.left:
|
|
queue.append(current.left)
|
|
if current.right:
|
|
queue.append(current.right)
|
|
|
|
return nodes
|
|
|
|
|
|
def preorder(tree, nodes=None):
|
|
nodes = nodes or []
|
|
if tree:
|
|
nodes.append(tree.item)
|
|
if tree.left:
|
|
preorder(tree.left, nodes)
|
|
if tree.right:
|
|
preorder(tree.right, nodes)
|
|
return nodes
|
|
|
|
|
|
def postorder(tree, nodes=None):
|
|
nodes = nodes or []
|
|
if tree:
|
|
if tree.left:
|
|
nodes = postorder(tree.left, nodes)
|
|
if tree.right:
|
|
nodes = postorder(tree.right, nodes)
|
|
nodes.append(tree.item)
|
|
|
|
return nodes
|
|
|
|
|
|
def inorder(tree, nodes=None):
|
|
nodes = nodes or []
|
|
if tree:
|
|
if tree.left:
|
|
nodes = inorder(tree.left, nodes)
|
|
nodes.append(tree.item)
|
|
if tree.right:
|
|
nodes = inorder(tree.right, nodes)
|
|
return nodes
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
bst = BST()
|
|
l = [10, 5, 6, 3, 8, 2, 1, 11, 9, 4]
|
|
for i in l:
|
|
bst.add(i)
|
|
|
|
print
|
|
print "Searching for nodes 16 and 6:"
|
|
print bst.search(16)
|
|
print bst.search(6)
|
|
|
|
print
|
|
print 'Traversals:'
|
|
print 'Original: ', l
|
|
print 'Preorder: ', preorder(bst.root)
|
|
print 'Postorder: ', postorder(bst.root)
|
|
print 'Inorder: ', inorder(bst.root)
|
|
print 'BSF: ', BFT(bst) |