Structural Rotation: Definition
- Elaborate on the purpose of structural rotation.
Consider these numbers: $3, 5, 7$. The following are valid binary search trees made up of the given numbers. However, only one is "balanced."
data:image/s3,"s3://crabby-images/7859c/7859c34767be875e40af24559b7f7ad8dc7956e9" alt=""
data:image/s3,"s3://crabby-images/26f1c/26f1c4ef37aa868467f6b6f2e257d6d2c672cf23" alt=""
data:image/s3,"s3://crabby-images/4a02e/4a02e96671b81fbcc0bc9993fbebb9064979ae74" alt=""
data:image/s3,"s3://crabby-images/929c7/929c7dddc4ce2645af7cba19cf53ad5ad1921f89" alt=""
data:image/s3,"s3://crabby-images/26b5f/26b5fa83b8733538eb291d013d7c37e0aeb6360c" alt=""
The four unbalanced trees can be transformed to the balanced one using structural rotation. (Notice the balanced one can be generated from the sequence $5, 3, 7$ or $5, 7, 3$.)
A structural rotation is an operation on a binary tree that changes the tree's structure without affecting the order of the elements (as read in by an in-order traversal).
A structural rotation is often employed to balance two branches of different depths.
In a structural rotation, one node is shifted up, another is shifted down, and some of the remaining nodes may be shifted to ensure the tree is still a binary tree (each node only has two branches).
Structural rotations change the height of the tree by moving up larger subtrees.