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/dedb5/dedb52e3c4ccb0bcd8ebd9ee1973b3b26d0f2bfd" 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/48d77/48d7764eaad85d02692f889a8687dbba5d60a864" 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/8a594/8a594686f5d48b5689d31e0f0f961c8403e976bc" alt=""
The comparison is repeated until the parent is smaller than or equal to the percolating (swimming) element.
data:image/s3,"s3://crabby-images/07c7e/07c7ecf4e0a2baee694d548a13dda83a8d5fbdd8" 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.