A Heap is the nodes of the pairing heap.
Each node have two pointers: child going to the first child of this node,
and sibling goes to the next sibling of this tree.
So it actually encodes a forest where each node has children
node.child, node.child.sibling, node.child.sibling.sibling, etc.
Each edge in this forest denotes a le a b relation that has been checked, so
the root is smaller than everything else under it.
- nil
{α : Type u}
: Heap α
An empty forest, which has depth
0. - node
{α : Type u}
(a : α)
(child sibling : Heap α)
: Heap α
A forest consists of a root
a, a forestchildelements greater thana, and another forestsibling.
Instances For
O(n). The number of elements in the heap.
Equations
Instances For
A node containing a single element a.
Equations
Instances For
O(1). Is the heap empty?
Equations
Instances For
O(1). Get the smallest element in the heap, including the passed in value a.
Equations
Instances For
O(1). Get the smallest element in the heap, if it has an element.
Equations
Instances For
O(n log n). Monadic fold over the elements of a heap in increasing order,
by repeatedly pulling the minimum element out of the heap.
Equations
Instances For
O(n). Fold a function over the tree structure to accumulate a value.
Equations
Instances For
O(n). Convert the heap to a list in arbitrary order.
Equations
Instances For
O(n). Convert the heap to an array in arbitrary order.
Equations
Instances For
The well formedness predicate for a heap node. It asserts that:
- If
ais added at the top to make the forest into a tree, the resulting tree is ale-min-heap (ifleis well-behaved)
Equations
Instances For
The well formedness predicate for a pairing heap. It asserts that:
- There is no more than one tree.
- It is a
le-min-heap (ifleis well-behaved)
- nil
{α : Type u_1}
{le : α → α → Bool}
: WF le Heap.nil
It is an empty heap.
- node
{α : Type u_1}
{le : α → α → Bool}
{a : α}
{c : Heap α}
(h : NodeWF le a c)
: WF le (Heap.node a c Heap.nil)
There is exactly one tree and it is a
le-min-heap.
Instances For
A pairing heap is a data structure which supports the following primary operations:
insert : α → PairingHeap α → PairingHeap α: add an element to the heapdeleteMin : PairingHeap α → Option (α × PairingHeap α): remove the minimum element from the heapmerge : PairingHeap α → PairingHeap α → PairingHeap α: combine two heaps
The first two operations are known as a "priority queue", so this could be called
a "mergeable priority queue". The standard choice for a priority queue is a binary heap,
which supports insert and deleteMin in O(log n), but merge is O(n).
With a PairingHeap, insert and merge are O(1), deleteMin is amortized O(log n).
Note that deleteMin may be O(n) in a single operation. So if you need an efficient
persistent priority queue, you should use other data structures with better worst-case time.
Equations
Instances For
O(1). Make a new empty pairing heap.
Equations
Instances For
O(1). Make a new empty pairing heap.
Equations
Instances For
Equations
O(1). Is the heap empty?
Equations
Instances For
O(n). The number of elements in the heap.
Equations
Instances For
O(1). Make a new heap containing a.
Equations
Instances For
O(1). Merge the contents of two heaps.
Equations
Instances For
O(1). Add element a to the given heap h.
Equations
Instances For
O(n log n). Construct a heap from a list by inserting all the elements.
Equations
Instances For
O(n log n). Construct a heap from a list by inserting all the elements.
Equations
Instances For
Amortized O(log n). Remove and return the minimum element from the heap.
Equations
Instances For
O(1). Returns the smallest element in the heap, or none if the heap is empty.
Equations
Instances For
O(1). Returns the smallest element in the heap, or panics if the heap is empty.
Equations
Instances For
O(1). Returns the smallest element in the heap, or default if the heap is empty.
Equations
Instances For
Amortized O(log n). Removes the smallest element from the heap, or none if the heap is empty.
Equations
Instances For
Amortized O(log n). Removes the smallest element from the heap, if possible.
Equations
Instances For
O(n log n). Convert the heap to a list in increasing order.
Equations
Instances For
O(n log n). Convert the heap to an array in increasing order.
Equations
Instances For
O(n). Convert the heap to a list in arbitrary order.
Equations
Instances For
O(n). Convert the heap to an array in arbitrary order.