Binary Search Tree Rotation Algorithm
Goals
Students will understand elements of the rotation algorithm for binary search trees.
Video
Materials
One deck of Acorn cards.
data:image/s3,"s3://crabby-images/c4313/c431370a7a95b9088bb999e0d99c456904305760" alt="this is a placeholder image"
Setup
Shuffle the deck and deal each student 9 cards.
Each student will shuffle their 9 cards, and then create a binary tree as demonstrated on the insertion algorithm page.
data:image/s3,"s3://crabby-images/c43b1/c43b1f2b0029a4b4895effe95337a6a9bd031f63" alt="this is a placeholder image"
Algorithm
The card chosen to be rotated is our root card. The child of the root card on the opposite side of rotation is the pivot card, ex. the left child for a right rotation.
-
Replace the side of rotation child of the pivot card with the root card. Keep all of the root card children on the side of rotation intact. Set aside the side of rotation child and keep all of the children intact.
-
Place the side of rotation child of the pivot card that was replaced in step 1 as the opposite side of rotation child of the root card.
Example
This is an example of a right-side rotation of the root 35 of our tree.
Since this is a right-side rotation, the left child of our root, 25 is the pivot card.
data:image/s3,"s3://crabby-images/cb687/cb6874c0667b0829dbbb338b0ddca2a5a66df59d" alt="Sample tree created by insertion algorithm."
The side of rotation child 29 of the pivot card 25 is replaced by the root card 35, with all of the root card’s children intact. 29 has no children so only itself is set aside.
data:image/s3,"s3://crabby-images/aed1a/aed1a59bc10cbdb527ff870d2ca1c9cbd83fd7b2" alt="29 set aside, 35 and its children take its place."
The side of rotation child 29 is placed as the opposite side of rotation child of the root card.
data:image/s3,"s3://crabby-images/560a4/560a4fffcb175c6b0a3e09971a41f43916465839" alt="29 placed as the opposite side of rotation child of 35."