Remove Operation
- Trace the removal operation of Priority Queue with Binary Heap implementation.
Consider we have the following min-heap:
data:image/s3,"s3://crabby-images/3fb58/3fb58d07c9f7a2d6c0c1d8dcfd1550df6a91ab9c" alt=""
To remove the best, that is, to remove the minimum element, we can replace the root with the last element of the heap.
data:image/s3,"s3://crabby-images/99978/99978f37edc64c95b5f35447dacc56df7f2cb824" alt=""
Then, we will delete the last element.
data:image/s3,"s3://crabby-images/e7b78/e7b780805828a59149590805527229ccf4b66f4b" alt=""
Finally, we restore the heap property by percolating the new root down. This process is often called sink-down. It involves comparing the added element with its children and moving it down a level (swapping with the smaller of the two children) if needed.
data:image/s3,"s3://crabby-images/7d0c0/7d0c01a6441ca52855dcaf93435a06a8ed26dfa8" alt=""
The process is repeated until the children are smaller than or equal to the percolating (sinking) element.
data:image/s3,"s3://crabby-images/3979a/3979ac342212b36324e627c0400780e9e0d74952" alt=""
Or until the percolating (sinking) element reaches the deepest level.
data:image/s3,"s3://crabby-images/3aa6b/3aa6b902e54250f15a055b5a2c14bff4271eeab8" alt=""
Similar to insertion, the worst-case runtime for removal is $\Omicron(\lg n)$ since we need at most one swap on each heap level on the path from the root node to the deepest level.