mirror of
https://github.com/TheAlgorithms/Python.git
synced 2025-01-19 00:37:02 +00:00
Added delete function
This commit is contained in:
parent
54700f2c8f
commit
f766bb4216
|
@ -66,11 +66,29 @@ class BinarySearchTree:
|
||||||
parent_node.setRight(new_node)
|
parent_node.setRight(new_node)
|
||||||
#Set parent to the new node
|
#Set parent to the new node
|
||||||
new_node.setParent(parent_node)
|
new_node.setParent(parent_node)
|
||||||
'''
|
|
||||||
def delete(self):
|
def delete(self, label):
|
||||||
if (not self.empty()):
|
if (not self.empty()):
|
||||||
if()
|
#Look for the node with that label
|
||||||
'''
|
node = self.getNode(label)
|
||||||
|
#If the node exists
|
||||||
|
if(node is not None):
|
||||||
|
#If it has no children
|
||||||
|
if(node.getLeft() is None and node.getRight() is None):
|
||||||
|
self.__reassignNodes(node, None)
|
||||||
|
node = None
|
||||||
|
#Has only right children
|
||||||
|
elif(node.getLeft() is None and node.getRight() is not None):
|
||||||
|
self.__reassignNodes(node, node.getRight())
|
||||||
|
#Has only left children
|
||||||
|
elif(node.getLeft() is not None and node.getRight() is None):
|
||||||
|
self.__reassignNodes(node, node.getLeft())
|
||||||
|
#Has two children
|
||||||
|
else:
|
||||||
|
tmpNode = self.getMax(node.getLeft())
|
||||||
|
self.delete(tmpNode.getLabel())
|
||||||
|
self.__reassignNodes(node, tmpNode)
|
||||||
|
|
||||||
def getNode(self, label):
|
def getNode(self, label):
|
||||||
curr_node = None
|
curr_node = None
|
||||||
#If the tree is not empty
|
#If the tree is not empty
|
||||||
|
@ -89,18 +107,23 @@ class BinarySearchTree:
|
||||||
curr_node = curr_node.getRight()
|
curr_node = curr_node.getRight()
|
||||||
return curr_node
|
return curr_node
|
||||||
|
|
||||||
def getMax(self):
|
def getMax(self, root = None):
|
||||||
|
if(root is not None):
|
||||||
|
curr_node = root
|
||||||
|
else:
|
||||||
#We go deep on the right branch
|
#We go deep on the right branch
|
||||||
curr_node = None
|
|
||||||
if(not self.empty()):
|
|
||||||
curr_node = self.getRoot()
|
curr_node = self.getRoot()
|
||||||
|
if(not self.empty()):
|
||||||
while(curr_node.getRight() is not None):
|
while(curr_node.getRight() is not None):
|
||||||
curr_node = curr_node.getRight()
|
curr_node = curr_node.getRight()
|
||||||
return curr_node
|
return curr_node
|
||||||
|
|
||||||
def getMin(self):
|
def getMin(self, root = None):
|
||||||
|
if(root is not None):
|
||||||
|
curr_node = root
|
||||||
|
else:
|
||||||
#We go deep on the left branch
|
#We go deep on the left branch
|
||||||
curr_node = None
|
curr_node = self.getRoot()
|
||||||
if(not self.empty()):
|
if(not self.empty()):
|
||||||
curr_node = self.getRoot()
|
curr_node = self.getRoot()
|
||||||
while(curr_node.getLeft() is not None):
|
while(curr_node.getLeft() is not None):
|
||||||
|
@ -121,6 +144,24 @@ class BinarySearchTree:
|
||||||
def getRoot(self):
|
def getRoot(self):
|
||||||
return self.root
|
return self.root
|
||||||
|
|
||||||
|
def __isRightChildren(self, node):
|
||||||
|
if(node == node.getParent().getRight()):
|
||||||
|
return True
|
||||||
|
return False
|
||||||
|
|
||||||
|
def __reassignNodes(self,node, newChildren):
|
||||||
|
if(newChildren is not None):
|
||||||
|
newChildren.setParent(node.getParent())
|
||||||
|
if(node.getParent() is not None):
|
||||||
|
#If it is the Right Children
|
||||||
|
if(self.__isRightChildren(node)):a
|
||||||
|
node.getParent().setRight(newChildren)
|
||||||
|
else:
|
||||||
|
#Else it is the left children
|
||||||
|
node.getParent().setLeft(newChildren)
|
||||||
|
else:
|
||||||
|
#It is the root of the tree
|
||||||
|
node.setLabel(newChildren.getLabel())
|
||||||
|
|
||||||
def testBinarySearchTree():
|
def testBinarySearchTree():
|
||||||
'''
|
'''
|
||||||
|
@ -134,16 +175,27 @@ def testBinarySearchTree():
|
||||||
4 7 13
|
4 7 13
|
||||||
'''
|
'''
|
||||||
|
|
||||||
|
'''
|
||||||
|
Example After Deletion
|
||||||
|
7
|
||||||
|
/ \
|
||||||
|
3 14
|
||||||
|
/ \
|
||||||
|
1 6
|
||||||
|
/
|
||||||
|
4
|
||||||
|
'''
|
||||||
t = BinarySearchTree()
|
t = BinarySearchTree()
|
||||||
t.insert(8)
|
t.insert(8)
|
||||||
t.insert(3)
|
t.insert(3)
|
||||||
t.insert(1)
|
t.insert(10)
|
||||||
t.insert(6)
|
t.insert(6)
|
||||||
t.insert(4)
|
t.insert(1)
|
||||||
t.insert(7)
|
|
||||||
t.insert(10)
|
t.insert(10)
|
||||||
t.insert(14)
|
t.insert(14)
|
||||||
t.insert(13)
|
t.insert(13)
|
||||||
|
t.insert(4)
|
||||||
|
t.insert(7)
|
||||||
|
|
||||||
t.preShow(t.getRoot())
|
t.preShow(t.getRoot())
|
||||||
|
|
||||||
|
@ -161,5 +213,11 @@ def testBinarySearchTree():
|
||||||
print("Max Value: ", t.getMax().getLabel())
|
print("Max Value: ", t.getMax().getLabel())
|
||||||
print("Min Value: ", t.getMin().getLabel())
|
print("Min Value: ", t.getMin().getLabel())
|
||||||
|
|
||||||
|
t.delete(13)
|
||||||
|
t.delete(10)
|
||||||
|
t.delete(8)
|
||||||
|
|
||||||
|
t.preShow(t.getRoot())
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
testBinarySearchTree()
|
testBinarySearchTree()
|
||||||
|
|
Loading…
Reference in New Issue
Block a user