Treap Removal: 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/d76a2/d76a2a473223d43705a9f561593ed64ca3442563" alt=""
Exercise Show the result of removing the key T, including any necessary rotations.
Solution
After finding node with key T we set its priority to $-1$:
data:image/s3,"s3://crabby-images/85f6e/85f6ed021174d08e5053627971a0123042ba34e8" alt=""
We must now apply tree rotations to fix the max-heap order property. Among the children of T, the node with key Y has the highest priority. So we must apply a left rotation to bring Y above T:
data:image/s3,"s3://crabby-images/77150/77150f7baab2136a74c0884e1f0add09866639e2" alt=""
Among the children of T, the node with key P has the highest priority. So we must apply a right rotation to bring P above T:
data:image/s3,"s3://crabby-images/2816c/2816c58c355e266ecf7334962fedbf3b7ad23b53" alt=""
Notice at this point we can simply remove T (since it has only one child). If we were to follow the process completely, we would have to apply another left rotation to bring X above T:
data:image/s3,"s3://crabby-images/367c2/367c2a55c913306ba8d7e435354e43c2c9a7f775" alt=""
We can easily remove the node with key T as it is a leaf now.
data:image/s3,"s3://crabby-images/fa393/fa39314f33d63c3fcddd29c87d6e743733c66e74" alt=""