Addressable heap
From HandWiki
In computer science, an addressable heap is an abstract data type. Specifically, it is a mergeable heap supporting access to the elements of the heap via handles (also called references). It allows the key of the element referenced by a particular handle to be removed or decreased.
Definition
An addressable heap supports the following operations:[1]
Make-Heap()
, creating an empty heap.Insert(H,x)
, inserting an elementx
into the heapH
, and returning a handle to it.Min(H)
, returning a handle to the minimum element, orNil
if no such element exists.Extract-Min(H)
, extracting and returning a handle to the minimum element, orNil
if no such element exists.Remove(h)
, removing the element referenced byh
(from its respective heap).Decrease-Key(h,k)
, decreasing the key of the element referenced byh
tok
; illegal ifk
is larger than the key referenced byh
.Merge(H1,H2)
, combining the elements ofH1
andH2
.
Examples
Examples of addressable heaps include:
A more complete list with performance comparisons can be found here.
References
- ↑ Mehlhorn, Kurt; Sanders, Peter (2008). Algorithms and Data Structures: The Basic Toolbox. Springer. ISBN 978-3-540-77977-3. http://people.mpi-inf.mpg.de/~mehlhorn/ftp/Toolbox/PriorityQueues.pdf.
Original source: https://en.wikipedia.org/wiki/Addressable heap.
Read more |