Treap Removal: Exercise
- Select the appropriate rotation type to rebalance a Treap after performing a removal.
Consider the following (max-heap) treap, where the keys are the letters and the priorities are the integers:
data:image/s3,"s3://crabby-images/a9510/a9510ea65ace97d5c26d1080b8bccba6da2ae761" alt=""
Exercise Show the result of removing the key T, including any necessary rotations.
Solution
After finding the node with key T we set its priority to $-1$:
data:image/s3,"s3://crabby-images/7cbfd/7cbfd5e58e4b20627454bcac6e0d491e7155b3da" 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/c566b/c566bf0f3150d7559bd27689afb060e3d81cd37d" 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/d29f0/d29f0bc47bb3ea7c2e2446266716016fdd0d351d" 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/26601/26601af727c4b2af4078c9e8bab985f673174d5d" alt=""
We can easily remove the node with key T as it is a leaf now.
data:image/s3,"s3://crabby-images/64e81/64e814773702d3d07d255ef6d74c09de155bcde8" alt=""