Min-max heaps were developed in “Min-max heaps and generalized priority queues,” by M. Atkinson, J. Sack, N. Santoro, and T. Strothotte, Communications of (he ACM, 29: 10, 1986, pp. 996-1000. This paper also contains extensions of rnin-max heaps. The deap data structure- was invented by Svante Carlsson. The reference is “The deap: A double-ended heap to implement double-ended priority queues,” Information Processing Letters, 26, 1987, pp. 33-36. Leftist trees were invented by C. Crane. See, Linear Lists and Priority Queues as Balanced Binary Trees, Technical report CS-72-259, Computer Science Dept., Stanford University, Palo Alto, CA, 1972. Further discussion of.leftist trees may be found in Data Structures and Network Algorithms, by R. Tarjan…sIAM, Philadelphia, PA, 1983. The exercise on lazy deletion is from “Finding minimum spanning trees,” by D. Cheriton and R. Tarjan, SIAM Journal on Computing, 5,1976, pp. 724-742. B-heaps and F-heaps were invented by M. Fredman and R. Tarjan. Their work is reported in the paper “Fibonacci heaps and their uses in improved network optimization algorithms,” JACM, 34:3, 1987, pp. 596-615. This paper also describes several variant s of the basic F-heap as discussed here, as well as the application of F-heaps to the assignment problem and to the problem of finding a minimum-cost spanning tree. Their result is that using F-heaps, minimum-cost spanning trees can be found in O(e~(e,I1» time, where ~(e,n) :5log*n when e 2:n. log*n = min{i Ilog(i)n :5 I},log(O)n = n, and log(i)n = log(log(i-l)n). The complexity of finding minimum-cost spanning trees has been further reduced to O(elog~(e,n». The reference for this is “Efficient algorithms for finding minimum spanning trees in undirected and directed graphs,” by H. Gabow, Z. Galil, T. Spencer, and R. Tarjan, Combinatorica, 6:2, 1986, pp. 109-122.

ADDITIONAL EXERCISE

1. [Programming Project:] Implement the inheritance hierarchy of Figure 9.23 consisting of data structures described in Chapters 5 and 9. Dashed boxes represent abstract base classes. The abstract base class MergeableMinPQ represents an ADT which, in addition to being a min priority queue, contains an operation that merges two min priority queues. The dotted box represents all corresponding max ADTs not shown in the figure .