Structural Rotation: Definition
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/777f1/777f19105256e64bca94480a61e4a88d5ece1a2b" alt=""
data:image/s3,"s3://crabby-images/c0f90/c0f908dc7a307c6c49c283f8f2d54e04531e7f2e" alt=""
data:image/s3,"s3://crabby-images/52b74/52b74be1faa3ea48712862dc4c35c34fbb6e86f9" alt=""
data:image/s3,"s3://crabby-images/c76b2/c76b2e8ebce7027401b15c3587036fe5ec50fd50" alt=""
data:image/s3,"s3://crabby-images/e24b4/e24b44741c62c94a95e73b460898fa75bc9fd1f7" alt=""
It turns out, 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 structure of the tree without affecting the order of the elements (as read in by an in-order traversal).
It is used to balance out 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 2 branches).
Structural rotations change the height of the tree by moving up larger subtrees.