The implicit representation of a complete binary tree as an array,
or list, seems to have been first proposed by Eytzinger [24],
as a representation for pedigree family trees. The
data
structure described here was first introduced by Williams [69].
The randomized
data structure described here appears
to have first been proposed by Gambin and Malinowski [31].
Other meldable heap implementations exist, including leftist heaps
[13,43, Section 5.3.2], binomial heaps [66], Fibonacci
heaps [29], pairing heaps [28], and skew heaps
[63], although none of these are as simple as the
structure.
Some of the above structures also support a
operation
in which the value stored at node
is decreased to
. (It is a
pre-condition that
.) This operation can be implemented
in
time in most of the above structures by removing node
and adding
. However, some of these structures can implement
more efficiently. In particular,
takes
amortized time in Fibonacci heaps and
amortized time in a special version of pairing heaps [22].
This more efficient
operation has applications in
speeding up several graph algorithms including Dijkstra's shortest path
algorithm [29].
Exercise 10..1
Illustrate the addition of the values 7 and then 3 to the
data:image/s3,"s3://crabby-images/2cea6/2cea614659254a765a2f7b68fe0b64355b4176ff" alt="$ \mathtt{BinaryHeap}$"
shown at the end of Figure
10.2.
Exercise 10..2
Illustrate the removal of the next two values (6 and 8) on the
data:image/s3,"s3://crabby-images/2cea6/2cea614659254a765a2f7b68fe0b64355b4176ff" alt="$ \mathtt{BinaryHeap}$"
shown at the end of Figure
10.3.
Exercise 10..3
Implement the
data:image/s3,"s3://crabby-images/0bf19/0bf199d3661879586f584045bf093ea89bc8d6c0" alt="$ \mathtt{remove(i)}$"
method, that removes the value stored in
![$ \mathtt{a[i]}$](img215.png)
in a
data:image/s3,"s3://crabby-images/2cea6/2cea614659254a765a2f7b68fe0b64355b4176ff" alt="$ \mathtt{BinaryHeap}$"
. This method should run in
data:image/s3,"s3://crabby-images/eb5b2/eb5b2c9a0ed28ab420ac1bc978e02c70f88d4dc6" alt="$ O(\log \ensuremath{\mathtt{n}})$"
time.
Next, explain why this method is not likely to be useful.
Exercise 10..4
A
data:image/s3,"s3://crabby-images/db6a7/db6a78c30e91afd8e101c934fe13e1dfb8ff71f3" alt="$ d$"
-ary tree is a generalization of a binary tree in which each
internal node has
data:image/s3,"s3://crabby-images/db6a7/db6a78c30e91afd8e101c934fe13e1dfb8ff71f3" alt="$ d$"
children. Using Eytzinger's method it is also
possible to represent complete
data:image/s3,"s3://crabby-images/db6a7/db6a78c30e91afd8e101c934fe13e1dfb8ff71f3" alt="$ d$"
-ary trees using arrays. Work out
the equations that, given an index
data:image/s3,"s3://crabby-images/ec1c5/ec1c5e79f3915f1862d24865cddb5ac16943f9ba" alt="$ \mathtt{i}$"
, determine the index of
data:image/s3,"s3://crabby-images/ec1c5/ec1c5e79f3915f1862d24865cddb5ac16943f9ba" alt="$ \mathtt{i}$"
's
parent and each of
data:image/s3,"s3://crabby-images/ec1c5/ec1c5e79f3915f1862d24865cddb5ac16943f9ba" alt="$ \mathtt{i}$"
's
data:image/s3,"s3://crabby-images/db6a7/db6a78c30e91afd8e101c934fe13e1dfb8ff71f3" alt="$ d$"
children in this representation.
Exercise 10..5
Using what you learned in Exercise
10.4, design and
implement a
data:image/s3,"s3://crabby-images/e3661/e36618e34a4d5eb248430f1b3b3e7c5abb4e1c70" alt="$ \mathtt{DaryHeap}$"
, the
data:image/s3,"s3://crabby-images/db6a7/db6a78c30e91afd8e101c934fe13e1dfb8ff71f3" alt="$ d$"
-ary generalization of a
data:image/s3,"s3://crabby-images/2cea6/2cea614659254a765a2f7b68fe0b64355b4176ff" alt="$ \mathtt{BinaryHeap}$"
. Analyze the running times of operations on a
data:image/s3,"s3://crabby-images/e3661/e36618e34a4d5eb248430f1b3b3e7c5abb4e1c70" alt="$ \mathtt{DaryHeap}$"
and test the performance of your
data:image/s3,"s3://crabby-images/e3661/e36618e34a4d5eb248430f1b3b3e7c5abb4e1c70" alt="$ \mathtt{DaryHeap}$"
implementation against
that of the
data:image/s3,"s3://crabby-images/2cea6/2cea614659254a765a2f7b68fe0b64355b4176ff" alt="$ \mathtt{BinaryHeap}$"
implementation given here.
Exercise 10..6
Illustrate the addition of the values 17 and then 82 in the
data:image/s3,"s3://crabby-images/e0598/e0598e0c2983d44b95987d5bd314eb9ee52ec838" alt="$ \mathtt{h1}$"
shown in Figure
10.4. Use a coin to
simulate a random bit when needed.
Exercise 10..7
Illustrate the removal of the next two values (4 and 8) in the
data:image/s3,"s3://crabby-images/e0598/e0598e0c2983d44b95987d5bd314eb9ee52ec838" alt="$ \mathtt{h1}$"
shown in Figure
10.4. Use a coin to
simulate a random bit when needed.
Exercise 10..8
Implement the
data:image/s3,"s3://crabby-images/8e7be/8e7bed847fba8c87dcb5118f0812a94134c88554" alt="$ \mathtt{remove(u)}$"
method, that removes the node
data:image/s3,"s3://crabby-images/07d79/07d79e9fccb5c80668be13b4c9b6546e6a1ea406" alt="$ \mathtt{u}$"
from
a
data:image/s3,"s3://crabby-images/9ccd4/9ccd4613530380246277425f0a96a160f4914cb5" alt="$ \mathtt{MeldableHeap}$"
. This method should run in
data:image/s3,"s3://crabby-images/eb5b2/eb5b2c9a0ed28ab420ac1bc978e02c70f88d4dc6" alt="$ O(\log \ensuremath{\mathtt{n}})$"
expected time.
Exercise 10..9
Show how, in a
data:image/s3,"s3://crabby-images/2cea6/2cea614659254a765a2f7b68fe0b64355b4176ff" alt="$ \mathtt{BinaryHeap}$"
or
data:image/s3,"s3://crabby-images/9ccd4/9ccd4613530380246277425f0a96a160f4914cb5" alt="$ \mathtt{MeldableHeap}$"
, to find the second
smallest value in constant time.
Exercise 10..10
Show how, in a
data:image/s3,"s3://crabby-images/2cea6/2cea614659254a765a2f7b68fe0b64355b4176ff" alt="$ \mathtt{BinaryHeap}$"
or
data:image/s3,"s3://crabby-images/9ccd4/9ccd4613530380246277425f0a96a160f4914cb5" alt="$ \mathtt{MeldableHeap}$"
, to find the
data:image/s3,"s3://crabby-images/365ed/365edbc86970c9a3962652e51cf7760d78cf10bc" alt="$ k$"
th
smallest value in
data:image/s3,"s3://crabby-images/a4467/a44672ecdd19e1b72ac83efb8aaab7fb6b1bdfdb" alt="$ O(k\log k)$"
time. (Hint: Using another heap might
help.)
Exercise 10..11
Suppose you are given
data:image/s3,"s3://crabby-images/d7797/d7797bee70a64cb7494ac24fe2bafd4f30461e82" alt="$ \mathtt{k}$"
sorted lists, of total length
data:image/s3,"s3://crabby-images/8831c/8831c025e0c7d2ed3ddfa5e87085a075d5c855f9" alt="$ \mathtt{n}$"
. Show how,
using a heap, to merge these into a single sorted list in
data:image/s3,"s3://crabby-images/7fa6c/7fa6cb5b2dfe5fce774812bbe525299585c83743" alt="$ O(n\log
k)$"
time. (Hint: Starting with the case
data:image/s3,"s3://crabby-images/de1a7/de1a7e26a819cdee87f7f552c5994b92d5aea398" alt="$ k=2$"
can be instructive.)
opendatastructures.org