Treap Insertion: Exercise
Consider the following (max-heap) treap, where the keys are the letters and the priorities are the integers:
data:image/s3,"s3://crabby-images/0709c/0709c8fec2adb7ddb9d85cadd045f2949b9487e0" 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/7f88e/7f88e85976ae65129d7df066a52ed9c6b369c096" 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/d70b1/d70b1b5794eb75be7ee18f79ddc83e8aca467846" alt=""
Since the priority of M is larger than priority of T we must apply tree rotation again to bring M above T:
data:image/s3,"s3://crabby-images/bdecc/bdeccee419c1201f12b7a3a993799ff45839ee09" alt=""
We must apply a rotation one last time; this time, however, we apply left rotation since M is to the right of J:
data:image/s3,"s3://crabby-images/9f42a/9f42ae8f90eaac458eb3176e992b5ac68895ce07" alt=""
Notice the BST order property is maintained over the keys (letters) and the max-heap order property is maintained over the priorities (integers).