diff --git a/data_structures/BinaryTree.java b/data_structures/BinaryTree.java new file mode 100644 index 00000000..90a6d980 --- /dev/null +++ b/data_structures/BinaryTree.java @@ -0,0 +1,192 @@ +//A binary tree is a data structure in which an element has two successors(children) +//The left child is usually smaller than the parent, and the right child is usually bigger +class Node{ + public int data; + public Node left; + public Node right; + public Node parent; + + public Node(int value){ + data = value; + left = null; + right = null; + parent = null; + } +} + +class Tree{ + private Node root; + + public Tree(){ + root = null; + } + //Returns the node if it finds it, otherwise returns the parent + public Node find(int key){ + Node current = root; + Node last = root; + while(current != null){ + last = current; + if(key < current.data) + current = current.left; + else if(key > current.data) + current = current.right; + //If you find the value return it + else + return current; + } + return last; + } + + //Inserts the given value + public void put(int value){ + Node newNode = new Node(value); + if(root == null) + root = newNode; + else{ + //This will return the soon to be parent of the value you're inserting + Node parent = find(value); + + //This if/else assigns the new node to be either the left or right child of the parent + if(value < parent.data){ + parent.left = newNode; + parent.left.parent = parent; + return; + } + else{ + parent.right = newNode; + parent.right.parent = parent; + return; + } + } + } + + //Deletes the given value + public boolean remove(int value){ + //temp is the node to be deleted + Node temp = find(value); + + //If the value doesn't exist + if(temp.data != value) + return false; + + //No children + if(temp.right == null && temp.left == null){ + if(temp == root) + root = null; + + //This if/else assigns the new node to be either the left or right child of the parent + else if(temp.parent.data < temp.data) + temp.parent.right = null; + else + temp.parent.left = null; + return true; + } + + //Two children + else if(temp.left != null && temp.right != null){ + Node succesor = findSuccesor(temp); + + //The left tree of temp is made the left tree of the successor + succesor.left = temp.left; + succesor.left.parent = succesor; + + //If the successor has a right child, the child's grandparent is it's new parent + if(succesor.right != null && succesor.parent != temp){ + succesor.right.parent = succesor.parent; + succesor.parent.left = succesor.right; + succesor.right = temp.right; + succesor.right.parent = succesor; + } + if(temp == root){ + succesor.parent = null; + root = succesor; + return true; + } + + //If you're not deleting the root + else{ + succesor.parent = temp.parent; + + //This if/else assigns the new node to be either the left or right child of the parent + if(temp.parent.data < temp.data) + temp.parent.right = succesor; + else + temp.parent.left = succesor; + return true; + } + } + //One child + else{ + //If it has a right child + if(temp.right != null){ + if(temp == root){ + root = temp.right; return true;} + + temp.right.parent = temp.parent; + + //Assigns temp to left or right child + if(temp.data < temp.parent.data) + temp.parent.left = temp.right; + else + temp.parent.right = temp.right; + return true; + } + //If it has a left child + else{ + if(temp == root){ + root = temp.left; return true;} + + temp.left.parent = temp.parent; + + //Assigns temp to left or right side + if(temp.data < temp.parent.data) + temp.parent.left = temp.left; + else + temp.parent.right = temp.left; + return true; + } + } + } + + //Move right once and go left down the tree as far as you can + public Node findSuccesor(Node n){ + if(n.right == null) + return n; + Node current = n.right; + Node parent = n.right; + while(current != null){ + parent = current; + current = current.left; + } + return parent; + } + + public Node getRoot(){ + return root; + } + + //Prints leftChild - root - rightChild + public void inOrder(Node localRoot){ + if(localRoot != null){ + inOrder(localRoot.left); + System.out.print(localRoot.data + " "); + inOrder(localRoot.right); + } + } + //Prints root - leftChild - rightChild + public void preOrder(Node localRoot){ + if(localRoot != null){ + System.out.print(localRoot.data + " "); + preOrder(localRoot.left); + preOrder(localRoot.right); + } + } + //Prints rightChild - leftChild - root + public void postOrder(Node localRoot){ + if(localRoot != null){ + postOrder(localRoot.left); + postOrder(localRoot.right); + System.out.print(localRoot.data + " "); + } + } +} \ No newline at end of file