Binary search tree. Adding a value
Adding a value to BST can be divided into two stages:
- search for a place to put a new element;
- insert the new element to this place.
Search for a place
At this stage analgorithm should follow binary search tree property. If a new value is less, than the current node's value, go to the left subtree, else go to the right subtree. Following this simple rule, the algorithm reaches a node, which has no left or right subtree. By the moment a place for insertion is found, we can say for sure, that a new value has no duplicate in the tree. Initially, a new node has no children, so it is a leaf. Let us see it at the picture. Gray circles indicate possible places for a new node.
data:image/s3,"s3://crabby-images/a73d1/a73d150152ed9fa23358d030c1a373f71e19a36b" alt="binary search tree places to add"
Now, let's go down to algorithm itself. Here and in almost every operation on BST recursion is utilized. Starting from the root,
- check, whether value in current node and a new value are equal. If so, duplicate is found. Otherwise,
- if a new value is less, than the node's value:
- if a current node has no left child, place for insertion has been found;
- otherwise, handle the left child with the same algorithm.
- if a new value is greater, than the node's value:
- if a current node has no right child, place for insertion has been found;
- otherwise, handle the right child with the same algorithm.
Example
Insert 4 to the tree, shown above.
data:image/s3,"s3://crabby-images/08985/0898581e633d78c9fe8a98f74b23694a4b93bec6" alt="BST insertion example, step 1"
data:image/s3,"s3://crabby-images/6ca73/6ca737856dbb5e8fb299be456bfd5b4036c5a4fc" alt="BST insertion example, step 2"
data:image/s3,"s3://crabby-images/87ceb/87ceb4ad2cc401530e686807e1f0782985643c21" alt="BST insertion example, step 3"
data:image/s3,"s3://crabby-images/18c24/18c2494b8ae2ff57c5b797c6ca8a2805386ab091" alt="BST insertion example, result"
Code snippets
The only the difference, between the algorithm above and the real routine is that first we should check, if a root exists. If not, just create it and don't run a common algorithm for this special case. This can be done in the BinarySearchTree class. Principal algorithm is implemented in the BSTNode class.
Java
public class BinarySearchTree {
…
public boolean add(int value) {
if (root == null) {
root = new BSTNode(value);
return true;
} else
return root.add(value);
}
}
public class BSTNode {
…
public boolean add(int value) {
if (value == this.value)
return false;
else if (value <this.value) {
if (left == null) {
left = new BSTNode(value);
return true;
} else
return left.add(value);
} else if (value > this.value) {
if (right == null) {
right = new BSTNode(value);
return true;
} else
return right.add(value);
}
return false;
}
}
C++
bool BinarySearchTree::add(int value) {
if (root == NULL) {
root = new BSTNode(value);
return true;
} else
return root->add(value);
}
bool BSTNode::add(int value) {
if (value == this->value)
return false;
else if (value < this->value) {
if (left == NULL) {
left = new BSTNode(value);
return true;
} else
return left->add(value);
} else if (value > this->value) {
if (right == NULL) {
right = new BSTNode(value);
return true;
} else
return right->add(value);
}
return false;
}
Visualizers
Recommended books
- Cormen, Leiserson, Rivest. Introduction to algorithms. (Theory)
- Aho, Ullman, Hopcroft. Data Structures and Algorithms. (Theory)
- Robert Lafore. Data Structures and Algorithms in Java. (Practice)
- Mark Allen Weiss. Data Structures and Problem Solving Using C++. (Practice)
data:image/s3,"s3://crabby-images/05223/052230532cfb5f673f7d26612f91568e85f64910" alt=""
Previous: Internal representation of a BST | Next: Search for a value in BST |
data:image/s3,"s3://crabby-images/05223/052230532cfb5f673f7d26612f91568e85f64910" alt=""
Contribute to AlgoList
Liked this tutorial? Please, consider making a donation. Contribute to help us keep sharing free knowledge and write new tutorials.
Every dollar helps!