CSCI 256
|
Only turn in problems from the second section.
Draw the skip list that results from performing the following sequence of operations on the skip list shown in Figure 3.42 of the skip list handout (taken from "Algorithm Engineering" by Goodrich and Tamassia): removeElement(38), insertItem(48,x), insertItem(24,y), removeelement(55). Assume the coin flips for the first insertion yield two heads followed by tails, while the coin flip for the second insertion yields tails. Note that insertItem(k,val) inserts the value "val" into the dictionary, using k as the key.
Solution:
-00 00 -00 17 00 -00 17 00 -00 17 31 42 48 00 -00 12 17 31 42 44 48 00 -00 12 17 20 24 31 39 42 44 48 50 00where -00 should be read as minus infinity and 00 represents infinity.
Problem 27.2-1 on page 599 of the text. In figure 27.1(b), what is the flow across the cut ({s, v2 ,v4},{v1, v3, t})? What is the capacity of this cut?
Solution: The flow is 19 (= 11 + 1 - 4 +7 + 4). The capacity is 31 (= 16 + 4 + 7 + 4).
Give a pseudo-code description of the removeElement dictionary operation, assuming the dictionary is implemented by a skip-list structure.
Solution:
Algorithm SkipRemove(k) p <- SkipSearch(k) if key(p) != k then return NO_SUCH_KEY while p != null removeFromHorizList(p) p <- above(p) return SUCCESSwhere removeFromHorizList(p) is the usual algorithm to remove a node from a doubly linked list (with links before and after).
Problem 27.1-6 on page 586 of the text. Given a flow network G = (V,E), let f1 and f2 be functions from V x V to R. The flow sum f1 + f2 is the function from V x V to R defined by (f1 + f2)(u,v) = f1(u,v) + f2(u,v) for all u, v in V. If f1 and f2 are flows in G, which of the three flow properties must the flow sum f1 + f2 satisfy, and which might it violate?
Solution:
(f1 + f2)(u,v) = f1(u,v) + f2(u,v) = -f1(v,u) - f2(v,u) = - (f1 + f2)(v,u)
(sum of (f1 + f2)(u,v) for all v) = (sum of f1(u,v) for all v) + (sum of f2(u,v) for all v) = 0 + 0
Back to:
kim@cs.williams.edu