Putting it all together!
- Select the appropriate rotation type to rebalance a BST after an insertion/removal operation is performed.
This is called a (single) right rotation:
data:image/s3,"s3://crabby-images/ed7cf/ed7cfa8c3783e8877c3f5d3dccf5e957d70215e3" alt=""
Cause of imbalance: left child's left subtree.
This is called a (single) left rotation:
data:image/s3,"s3://crabby-images/bf1a3/bf1a39e5885b9027c45bedb9f2bd9aec053f38c6" alt=""
Cause of imbalance: right child's right subtree.
This is called a (double) right-left rotation:
data:image/s3,"s3://crabby-images/b5a50/b5a502cf4b2b7fd3050dd81d8b681b0229977d15" alt=""
Cause of imbalance: right child's left subtree.
This is called a (double) left-right rotation:
data:image/s3,"s3://crabby-images/5b4ee/5b4ee4f8066dff49f56f5e003329f1dda3021f75" alt=""
Cause of imbalance: left child's right subtree.
Exercise Complete the following table which assists in determining type of rotation.
Imbalance Node | Child's bf = -1 (right heavy) | Child's bf = 1 (left heavy) |
---|---|---|
bf = -2 (right heavy) | ||
bf = 2 (left heavy) |
Solution
Imbalance Node | Child's bf = -1 (right heavy) | Child's bf = 1 (left heavy) |
---|---|---|
bf = -2 (right heavy) | Left | Right-Left |
bf = 2 (left heavy) | Left-Right | Right |
Caution The table above does not account for an edge case where the child's balance factor is $0$.
Schematic representation of tree rotations
Resources
- Wikipedia's entry on AVL Tree: Rebalancing.
- Wikipedia's entry on Tree Rotation.