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.
push
pop_max
pop_min