Treap: Deletion
- Explain and trace the balancing operations of a Treap.
- Explain the role of the priorities in rebalancing and the importance of being random.
Consider the following (max-heap) treap:
data:image/s3,"s3://crabby-images/be5e5/be5e5e4ed81c24f0d5bdba9083396629e2b42513" alt=""
Let's remove the node with key $2$.
We find the entry to be removed (look-up as in BST, ignoring priorities). Since we have a "max-heap" treap and the priorities are non-negative, we set the priority of the entry to be removed to $-1$:
data:image/s3,"s3://crabby-images/e8cdd/e8cdd3e1c8c8b8f7214a6a05161f5af9f0b759cd" alt=""
The max-heap order property is violated. To fix it, we need to bring the child node with key $3$ above the node with key $2$ (because $3$ has a higher priority between the children of $2$).
Since $3$ is to the right of $2$, we perform a left rotation:
data:image/s3,"s3://crabby-images/595b1/595b1a26d34163097e52bb01201b5a49e7b76843" alt=""
The max-heap order property is still violated. To fix it, we need to bring the child node with key $1$ above the node with key $2$. Since $1$ is to the left of $2$, we perform a right rotation:
data:image/s3,"s3://crabby-images/0eded/0eded09b5c4deb9243af117241ed6472ec2f9356" alt=""
We can easily remove the node with key $2$ as it is a leaf now.
data:image/s3,"s3://crabby-images/4b46d/4b46d990a27f766c99e6f669e3d551fdd0837de2" alt=""
Notice the resulting treap is a BST over the keys and a max-heap over the priorities, and its height is $\Omicron(\lg n)$.