Insert Operation
- Trace the insert 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 insert a new element, such as $7$, we initially appended it to the end of the heap. (So it goes to the last level, after the last element from left to right.)
data:image/s3,"s3://crabby-images/4126c/4126c12bdb8e59ae58bd6ded6e8dcb4fb62693d3" alt=""
We may have to "repair" the heap property by percolating the new node to its proper position. This process is often called swim-up. It involves comparing the added element with its parent and moving it up a level (swapping with the parent) if needed.
data:image/s3,"s3://crabby-images/ff2f3/ff2f3371507a9ffc7780693b8ef567bd13efac96" alt=""
The comparison is repeated until the parent is smaller than or equal to the percolating (swimming) element.
data:image/s3,"s3://crabby-images/3cad8/3cad8632c2411e1631706b7d156e871d3d23e9a8" alt=""
The worst-case runtime of the algorithm is $\Omicron(\lg n)$, since we need at most one swap on each level of a heap on the path from the inserted node to the root.