Remove Operation
- Trace the remove operation of Priority Queue with Binary Heap implementation.
Consider we have the following min-heap:
data:image/s3,"s3://crabby-images/dedb5/dedb52e3c4ccb0bcd8ebd9ee1973b3b26d0f2bfd" 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/60daa/60daadfd6487cd96eafdc9b9e071a6e26760127a" alt=""
Then, we will delete the last element.
data:image/s3,"s3://crabby-images/ec292/ec2928aca6a7669fe9cea14ec3b23f825b88f5fd" 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/ccbf8/ccbf8c8ed18b592e003d8bcd3ab668ed3fc1f348" alt=""
The process is repeated until the children are smaller than or equal to the percolating (sinking) element.
data:image/s3,"s3://crabby-images/6656d/6656d34e93e17ccf1acec8c16c9bba22faf663fa" alt=""
Or until the percolating (sinking) element reaches the deepest level.
data:image/s3,"s3://crabby-images/d3ff3/d3ff3a568bfd0ad85a41680e138d8d66150fda82" 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.