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/0c726/0c726e0650d8cf05f6f21d09284873aace1cab89" alt=""
Cause of imbalance: left child's left subtree.
This is called a (single) left rotation:
data:image/s3,"s3://crabby-images/48f5e/48f5e6cd3986c79f4bcf9802f94d45925d1c277f" alt=""
Cause of imbalance: right child's right subtree.
This is called a (double) right-left rotation:
data:image/s3,"s3://crabby-images/33b72/33b7254eec754fa465d0923315b63fe9644db9f2" alt=""
Cause of imbalance: right child's left subtree.
This is called a (double) left-right rotation:
data:image/s3,"s3://crabby-images/0d128/0d128098246c89163275b8ca007d8c65af550da8" alt=""
Cause of imbalance: left child's right subtree.
Exercise Complete the following table which assists in determining the 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.