Treap Insertion: Exercise
- Select the appropriate rotation type to rebalance a Treap after performing an insertion.
Consider the following (max-heap) treap, where the keys are the letters and the priorities are the integers:
data:image/s3,"s3://crabby-images/4bcfa/4bcfaeedb2b8217aaaf8f0f5b68c4b9e8682e1f1" alt=""
Exercise Show the result of inserting the key M, including any necessary rotations. Assume the priority generated for the key M is 15.
Solution
We insert M following the insertion process of a regular BST (ignoring priorities):
data:image/s3,"s3://crabby-images/db170/db17031623b4d1aeddebf5397677bfbb9340ec3c" alt=""
We must now apply tree rotations to fix the max-heap order property. Since M is to the left of P, we apply a right rotation to bring M above P and P to the right of M:
data:image/s3,"s3://crabby-images/783b9/783b978e73f08111ac9e9799ea2f7ae3cfb2c04a" alt=""
Since the priority of M is larger than the priority of T** we must apply tree rotation again to bring M above T:
data:image/s3,"s3://crabby-images/86bd1/86bd1ac473f8320b60513679efcc2a14ade3be5d" alt=""
We must apply a rotation one last time; this time, however, we apply a left rotation since M is to the right of J:
data:image/s3,"s3://crabby-images/733c5/733c51e1c49a212af92a076e281f630bddf336a8" alt=""
Notice the BST order property is maintained over the keys (letters) and the max-heap order property is maintained over the priorities (integers).