Insert Operation
Consider we have the following min-heap:
data:image/s3,"s3://crabby-images/470cb/470cb3b68382ab18e29be6fb914c5daee2ab8073" 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/89343/89343ad0cbbd8cc7a0077acd7c945b201de90e90" 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/a30dd/a30ddd00f6e858ad6ac8b6f785802a8aea7ff247" alt=""
The comparison is repeated until the parent is smaller than or equal to the percolating (swimming) element.
data:image/s3,"s3://crabby-images/19db4/19db41442e766535c690818baad4ce297f3b2f19" alt=""
The worst-case runtime of the algorithm is $O(\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.