The implicit representation of a complete binary tree as an array,
or list, seems to have been first proposed by Eytzinger [27].
He used this representation in books containing pedigree family trees
of noble families. The
data structure described here was
first introduced by Williams [76].
The randomized
data structure described here appears
to have first been proposed by Gambin and Malinowski [34].
Other meldable heap implementations exist, including
leftist heaps [16,48, Section 5.3.2],
binomial heaps [73],
Fibonacci heaps [30],
pairing heaps [29], and skew heaps [70],
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
.) In most of the preceding structures,
this operation can be supported in
time 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 [25].
This more efficient
operation has applications in
speeding up several graph algorithms, including Dijkstra's shortest path
algorithm [30].
Exercise 10..1
Illustrate the addition of the values 7 and then 3 to the
data:image/s3,"s3://crabby-images/e6aa2/e6aa23f6cb1993c9132f75f889e6a8a56bde5d6e" 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/0db41/0db418cb7252daa2376029ff120f61f37ed3da25" alt="$ \mathtt{BinaryHeap}$"
shown at the end of Figure
10.3.
Exercise 10..3
Implement the
data:image/s3,"s3://crabby-images/9b529/9b529b1c9def28f57ec815742a77b7684b83598c" alt="$ \mathtt{remove(i)}$"
method, that removes the value stored in
![$ \mathtt{a[i]}$](img4767.png)
in a
data:image/s3,"s3://crabby-images/3b537/3b537f4105461d24ef47e1246f17a35a75d01bb4" alt="$ \mathtt{BinaryHeap}$"
. This method should run in
data:image/s3,"s3://crabby-images/af0d6/af0d6be623fdac9a5efcfe0274541b911c2d97c3" 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/e3094/e30940d9dd45721f9503f2d1bef1173b003c9d32" alt="$ d$"
-ary tree is a generalization of a binary tree in which each
internal node has
data:image/s3,"s3://crabby-images/63614/63614591040a6bc4103f61b22416f25ae276d5ca" alt="$ d$"
children. Using Eytzinger's method it is also
possible to represent complete
data:image/s3,"s3://crabby-images/7a426/7a426f4d9fa5df84ee2f6d9feaeced492d4cc54d" alt="$ d$"
-ary trees using arrays. Work out
the equations that, given an index
data:image/s3,"s3://crabby-images/19596/19596f0dde0ba6158d10d28de401ec066bef4abd" alt="$ \mathtt{i}$"
, determine the index of
data:image/s3,"s3://crabby-images/2612c/2612c15351e29178afd7728a9639cd3257947ac6" alt="$ \mathtt{i}$"
's
parent and each of
data:image/s3,"s3://crabby-images/b832e/b832e6bcb4fbaa70e74a6b1fa7e6ef0124858b95" alt="$ \mathtt{i}$"
's
data:image/s3,"s3://crabby-images/2b4d9/2b4d913ae3c4eeba9960ba2229b798f7682ad712" 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/af7ea/af7ea9dd0663d8af002a2f79885314ab44f6ffbc" alt="$ \mathtt{DaryHeap}$"
, the
data:image/s3,"s3://crabby-images/94029/94029d70b4fc2da233f276c2239ed10c3c352cb7" alt="$ d$"
-ary generalization of a
data:image/s3,"s3://crabby-images/2047b/2047b72973bcdc35a483471b804e0e46cc0a8822" alt="$ \mathtt{BinaryHeap}$"
. Analyze the running times of operations on a
data:image/s3,"s3://crabby-images/d688f/d688ff15b64162dea85982c1c6f6658b9649c816" alt="$ \mathtt{DaryHeap}$"
and test the performance of your
data:image/s3,"s3://crabby-images/60026/600269381ff9c97114c2527fa1fcdf64bae44bf6" alt="$ \mathtt{DaryHeap}$"
implementation against
that of the
data:image/s3,"s3://crabby-images/242bb/242bb9a62694ac0f9f1ffce3f675204e103778ad" 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/78bc5/78bc5a673aa3995a1e1d0605b598f1c6495ff457" 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/7f651/7f65161a8e388184f49fa5b8b7eab332219f07dc" 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/d0df5/d0df572e2d065d5a2b6d8266ed496112fe273a60" alt="$ \mathtt{remove(u)}$"
method, that removes the node
data:image/s3,"s3://crabby-images/d4fad/d4fadf1cd948280e28ed4046535864be7cdaeab7" alt="$ \mathtt{u}$"
from
a
data:image/s3,"s3://crabby-images/dca64/dca6476f89b8f4c17c7f66b98ea9d52978d8cb03" alt="$ \mathtt{MeldableHeap}$"
. This method should run in
data:image/s3,"s3://crabby-images/72e1e/72e1e24b357a52106bf08ac1788647acf115e2c3" alt="$ O(\log \ensuremath{\mathtt{n}})$"
expected time.
Exercise 10..9
Show how to find the second smallest value in a
data:image/s3,"s3://crabby-images/830bf/830bf66580c1526077eb5ad45460253f41b3e789" alt="$ \mathtt{BinaryHeap}$"
or
data:image/s3,"s3://crabby-images/5b994/5b994be732beaa94cb08016634de32fde4b01db0" alt="$ \mathtt{MeldableHeap}$"
in constant time.
Exercise 10..10
Show how to find the
data:image/s3,"s3://crabby-images/d853f/d853f01130b675aaf92ba8839b425a63213ebfb5" alt="$ k$"
th smallest value in a
data:image/s3,"s3://crabby-images/63e61/63e6150ae3c2666fe965149e3f736567c9ad94a3" alt="$ \mathtt{BinaryHeap}$"
or
data:image/s3,"s3://crabby-images/b1720/b172010d900cf8e7d38d5d45dc8b3654d38f23a3" alt="$ \mathtt{MeldableHeap}$"
in
data:image/s3,"s3://crabby-images/a5c26/a5c260a8407d06e51ce2477bb1dd285ed5a3c68d" 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/c4775/c4775ebe88ea5532ad0eed98821632f05fe7d4cb" alt="$ \mathtt{k}$"
sorted lists, of total length
data:image/s3,"s3://crabby-images/630a2/630a243ed04dea597aa64f6f03beefceb6e860cb" alt="$ \mathtt{n}$"
. Using
a heap, show how to merge these into a single sorted list in
data:image/s3,"s3://crabby-images/ee9fa/ee9fa1cbca481d2cf2afe9e4855ed61c322da75e" alt="$ O(n\log
k)$"
time. (Hint: Starting with the case
data:image/s3,"s3://crabby-images/e355a/e355a4b2fd20785a7bcc1fe3c6c1aa58d461395a" alt="$ k=2$"
can be instructive.)
opendatastructures.org