Questions: Heaps
1) What is the running time in terms of O notation for Heap-Insert?
O(lg n), where n is the number of items currently in the heap
2) Create the pseudo code to implement the function Extract-Max procedure
given you can use the function Heapify.
suppose we have the heap
data:image/s3,"s3://crabby-images/685f0/685f08fdd711c63ed92f7a9b152fbbd6a03416d8" alt=""
now we extract the node (root) which represents the maximum value
and now we get
data:image/s3,"s3://crabby-images/03f62/03f628d5ad12a9e5ad1d5e5dd37b088381dd28cc" alt=""
We now have to make this back into a heap. We can almost run the
heapify procedure on the whole thing, except that we have two complete
binary trees, not one.
SOLUTION:
move lowest node that is farthest to the right into the root position.
You get
data:image/s3,"s3://crabby-images/70b86/70b863ccccca185427adb75319ccdffed9eec835" alt=""
NOW invoke Heapify:
>>>data:image/s3,"s3://crabby-images/dc9b5/dc9b5a8605b871b113330734a2d0115eec08745d" alt=""
The final result
|