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/622fb/622fb4b8cceb9f3f5afdcefb074430e2cb479e1c" alt=""
data:image/s3,"s3://crabby-images/063bf/063bfa1bdd1178b69703cf7dd452c604a9323f18" alt=""
data:image/s3,"s3://crabby-images/f42b4/f42b4236a363652c0a7c46884e4d223bebd03884" alt=""
data:image/s3,"s3://crabby-images/9352f/9352f8ac738fcd68c1de576cc0c9bf233698b237" alt=""
data:image/s3,"s3://crabby-images/d3e3f/d3e3f8922a8073d070e2662c9ccaac388d913de2" 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.