BiHeap

BiHeap is a implementation of heap structure, to maintain the extreme values of a list of data.

Use push to add a new value to the heap, and pop_max or pop_min to get the extreme value of the heap.