Right Rotation: Exercise III
- Trace Single Right Rotation.
Consider the following BST:
data:image/s3,"s3://crabby-images/4204d/4204dee32b644a500b424b65b4aef25bfdb1eb93" alt=""
Exercise Insert the value $3$ and apply a structural rotation to balance the BST if needed.
Solution
Let's observe the original BST is balanced:
data:image/s3,"s3://crabby-images/cf11b/cf11b842d932eaee12de87c63dc8f9b7134c0109" alt=""
Here is the BST after insertion:
data:image/s3,"s3://crabby-images/823ad/823ad3a1d5c5ee0e962cd1b57ba8d47076845795" alt=""
Notice the violation of balance property occurs in the great-grandparent of the inserted node. From the perspective of the great-grandparent node, the problem is caused in left child's left subtree. This is the pattern that requires a (single) right rotation. However, this case is a bit tricky:
When you bring $7$ to be the parent of $14$, the latter needs to go to the right of $7$. However, $11$ is already to the right of $7$. So we need to attach $11$ to the left of $14$ (where $7$ used to be).
data:image/s3,"s3://crabby-images/00050/000506c7efd2f2b23d04f6bcec7df3d58b2d612c" alt=""