CSE 326: Data Structures Priority Queues (Heaps)

Slides:



Advertisements
Similar presentations
§6 Leftist Heaps CHAPTER 5 Graph Algorithms  Heap: Structure Property + Order Property Target : Speed up merging in O(N). Leftist Heap: Order Property.
Advertisements

DATA STRUCTURES AND ALGORITHMS Lecture Notes 9 Prepared by İnanç TAHRALI.
COL 106 Shweta Agrawal and Amit Kumar
CMSC 341 Binary Heaps Priority Queues. 8/3/2007 UMBC CSMC 341 PQueue 2 Priority Queues Priority: some property of an object that allows it to be prioritized.
Priority Queues And the amazing binary heap Chapter 20 in DS&PS Chapter 6 in DS&AA.
1 CSE 326: Data Structures Priority Queues – Binary Heaps.
Binary Heaps CSE 373 Data Structures Lecture 11. 2/5/03Binary Heaps - Lecture 112 Readings Reading ›Sections
CSE 373 Data Structures Lecture 12
CSE 326: Data Structures Lecture #17 Priority Queues Alon Halevy Spring Quarter 2001.
CSE 326: Data Structures Binomial Queues Ben Lerner Summer 2007.
WEEK 3 Leftist Heaps CE222 Dr. Senem Kumova Metin CE222_Dr. Senem Kumova Metin.
1 Heaps (Priority Queues) You are given a set of items A[1..N] We want to find only the smallest or largest (highest priority) item quickly. Examples:
DATA STRUCTURES AND ALGORITHMS Lecture Notes 8 Prepared by İnanç TAHRALI.
1 CSE 326 Data Structures Part 6: Priority Queues, AKA Heaps Henry Kautz Autumn 2002.
Priority Queues (Heaps)
1 CSE 326: Data Structures Priority Queues (Heaps) Lecture 9: Monday, Jan 27, 2003.
CSE 326: Data Structures Lecture #6 Putting Our Heaps Together Steve Wolfman Winter Quarter 2000.
CSE373: Data Structures & Algorithms Lecture 8: AVL Trees and Priority Queues Linda Shapiro Spring 2016.
1 Chapter 6: Priority Queues, AKA Heaps. 2 Queues with special properties Consider applications –ordering CPU jobs –searching for the exit in a maze (or.
CSE332: Data Abstractions Lecture 7: AVL Trees
CSE373: Data Structures & Algorithms Priority Queues
School of Computing Clemson University Fall, 2012
Binary Search Trees One of the tree applications in Chapter 10 is binary search trees. In Chapter 10, binary search trees are used to implement bags.
Multiway Search Trees Data may not fit into main memory
Binary Search Trees.
B+ Trees What are B+ Trees used for What is a B Tree What is a B+ Tree
CSE373: Data Structures & Algorithms
CSE373: Data Structures & Algorithms Lecture 7: AVL Trees
October 30th – Priority QUeues
CSE373: Data Structures & Algorithms Lecture 7: AVL Trees
Hashing Exercises.
Heap Sort Example Qamar Abbas.
CMSC 341 Lecture 13 Leftist Heaps
Binary Search Trees Why this is a useful data structure. Terminology
CSE373: Data Structures & Algorithms Lecture 7: AVL Trees
Chapter 22 : Binary Trees, AVL Trees, and Priority Queues
CMSC 341 Lecture 10 B-Trees Based on slides from Dr. Katherine Gibson.
original list {67, 33,49, 21, 25, 94} pass { } {67 94}
CSE373: Data Structures & Algorithms Lecture 6: Binary Search Trees
CSE373: Data Structures & Algorithms Lecture 6: Binary Search Trees
CMSC 341: Data Structures Priority Queues – Binary Heaps
CSE 326 Heaps and the Priority Queue ADT
CSE 326: Data Structures Lecture #4 Heaps more Priority Qs
Lec 12 March 9, 11 Mid-term # 1 (March 21?)
CSE332: Data Abstractions Lecture 5: Binary Heaps, Continued
B+ Trees What are B+ Trees used for What is a B Tree What is a B+ Tree
Binary Search Trees One of the tree applications in Chapter 10 is binary search trees. In Chapter 10, binary search trees are used to implement bags.
David Kaplan Dept of Computer Science & Engineering Autumn 2001
Heaps and the Heapsort Heaps and priority queues
CSE 332: Data Abstractions Binary Search Trees
CSE373: Data Structures & Algorithms Lecture 5: AVL Trees
CSE 326: Data Structures Lecture #5 Political Heaps
A Robust Data Structure
CSE 332: Data Structures Priority Queues – Binary Heaps Part II
CSE 332: Data Abstractions AVL Trees
Binary and Binomial Heaps
CSE 373: Data Structures and Algorithms
CSE373: Data Structures & Algorithms Lecture 7: Binary Heaps, Continued Dan Grossman Fall 2013.
CSE 373 Data Structures and Algorithms
CSE 373 Data Structures and Algorithms
CSE 326: Data Structures Lecture #9 AVL II
CSE 373: Data Structures and Algorithms
Priority Queues CSE 373 Data Structures.
Richard Anderson Spring 2016
CSE 326: Data Structures Lecture #5 Heaps More
B-Trees.
Data Structures and Algorithm Analysis Priority Queues (Heaps)
CSE 373 Data Structures Lecture 12
Heaps & Multi-way Search Trees
326 Lecture 9 Henry Kautz Winter Quarter 2002
Presentation transcript:

CSE 326: Data Structures Priority Queues (Heaps) Lecture 10: Wednesday, Jan 28, 2003

New Operation: Merge Merge(H1,H2): Merge two heaps H1 and H2 of size O(N). E.g. Combine queues from two different sources to run on one CPU. Can do O(N) Insert operations: O(N log N) time Better: Copy H2 at the end of H1 (assuming array implementation) and use Floyd’s Method for BuildHeap. Running Time: O(N) Can we do even better? (i.e. Merge in O(log N) time?)

Binomial Queues All in O(log n) time insert : heap  value  heap findMin : heap  value deleteMin : heap  heap merge : heap  heap  heap All in O(log n) time Recursive Definition of Binomial Tree Bk of height k: B0 = single root node Bk = Attach Bk-1 to root of another Bk-1 Idea: a binomial heap H is a forest of binomial trees: H = B0 B1 B2 ... Bk where each Bi may be present, or may be empty

Building a Binomial Tree To construct a binomial tree Bk of height k: Take the binomial tree Bk-1 of height k-1 Place another copy of Bk-1 one level below the first Attach the root nodes Binomial tree of height k has exactly 2k nodes (by induction) B0 B1 B2 B3

Building a Binomial Tree To construct a binomial tree Bk of height k: Take the binomial tree Bk-1 of height k-1 Place another copy of Bk-1 one level below the first Attach the root nodes Binomial tree of height k has exactly 2k nodes (by induction) B0 B1 B2 B3

Building a Binomial Tree To construct a binomial tree Bk of height k: Take the binomial tree Bk-1 of height k-1 Place another copy of Bk-1 one level below the first Attach the root nodes Binomial tree of height k has exactly 2k nodes (by induction) B0 B1 B2 B3

Building a Binomial Tree To construct a binomial tree Bk of height k: Take the binomial tree Bk-1 of height k-1 Place another copy of Bk-1 one level below the first Attach the root nodes Binomial tree of height k has exactly 2k nodes (by induction) B0 B1 B2 B3

Building a Binomial Tree To construct a binomial tree Bk of height k: Take the binomial tree Bk-1 of height k-1 Place another copy of Bk-1 one level below the first Attach the root nodes Binomial tree of height k has exactly 2k nodes (by induction) B0 B1 B2 B3

Building a Binomial Tree To construct a binomial tree Bk of height k: Take the binomial tree Bk-1 of height k-1 Place another copy of Bk-1 one level below the first Attach the root nodes Binomial tree of height k has exactly 2k nodes (by induction) B0 B1 B2 B3

Building a Binomial Tree To construct a binomial tree Bk of height k: Take the binomial tree Bk-1 of height k-1 Place another copy of Bk-1 one level below the first Attach the root nodes Binomial tree of height k has exactly 2k nodes (by induction) B0 B1 B2 B3 Recall: a binomial heap may have any subset of these trees

Why Binomial? Why are these trees called binomial? B0 B1 B2 B3 Hint: how many nodes at depth d? B0 B1 B2 B3

Why Binomial? Why are these trees called binomial? Hint: how many nodes at depth d? Number of nodes at different depths d for Bk = [1], [1 1], [1 2 1], [1 3 3 1], … Binomial coefficients of (a + b)k : k!/((k-d)!d!) B0 B1 B2 B3

Binomial Queue Properties Suppose you are given a binomial queue of N nodes There is a unique set of binomial trees for N nodes What is the maximum number of trees that can be in an N-node queue? 1 node  1 tree B0; 2 nodes  1 tree B1; 3 nodes  2 trees B0 and B1; 7 nodes  3 trees B0, B1 and B2 … Trees B0, B1, …, Bk can store up to 20 + 21 + … + 2k = 2k+1 – 1 nodes = N. Maximum is when all trees are used. So, solve for (k+1). Number of trees is  log(N+1) = O(log N)

Definition of Binomial Queues Binomial Queue = “forest” of heap-ordered binomial trees B0 B2 B0 B1 B3 1 -1 21 3 5 7 2 1 3 9 6 8 11 5 7 Binomial queue H1 5 elements = 101 base 2  B2 B0 Binomial queue H2 11 elements = 1011 base 2  B3 B1 B0 6

findMin() In each Bi, the minimum key is at the root So scan sequentially B1, B2, ..., Bk, compute the smallest of their keys: Time: O(log n) (why ?) B0 B1 B2 B3

Binomial Queues: Merge Main Idea: Merge two binomial queues by merging individual binomial trees Since Bk+1 is just two Bk’s attached together, merging trees is easy Steps for creating new queue by merging: Start with Bk for smallest k in either queue. If only one Bk, add Bk to new queue and go to next k. Merge two Bk’s to get new Bk+1 by making larger root the child of smaller root. Go to step 2 with k = k + 1.

Example: Binomial Queue Merge H1: H2: 1 -1 3 5 21 7 2 1 3 9 6 8 11 5 7 6

Example: Binomial Queue Merge H1: H2: 1 -1 3 5 7 2 1 3 9 6 21 8 11 5 7 6

Example: Binomial Queue Merge H1: H2: 1 -1 5 7 2 1 3 9 6 3 8 11 5 7 21 6

Example: Binomial Queue Merge H1: H2: 1 -1 7 5 2 1 3 3 9 6 8 11 5 21 7 6

Example: Binomial Queue Merge H1: H2: -1 1 2 1 3 7 5 8 11 5 3 9 6 6 21 7

Example: Binomial Queue Merge H1: H2: -1 1 2 1 3 7 5 8 11 5 3 9 6 6 21 7

Binomial Queues: Merge and Insert What is the run time for Merge of two O(N) queues? How would you insert a new item into the queue?

Binomial Queues: Merge and Insert What is the run time for Merge of two O(N) queues? O(number of trees) = O(log N) How would you insert a new item into the queue? Create a single node queue B0 with new item and merge with existing queue Again, O(log N) time Example: Insert 1, 2, 3, …,7 into an empty binomial queue

Insert 1,2,…,7 1

Insert 1,2,…,7 1 2

Insert 1,2,…,7 3 1 2

Insert 1,2,…,7 3 1 2 4

Insert 1,2,…,7 1 2 3 4

Insert 1,2,…,7 1 5 2 3 4

Insert 1,2,…,7 1 5 2 3 6 4

Insert 1,2,…,7 1 5 7 2 3 6 4

Binomial Queues: DeleteMin Steps: Find tree Bk with the smallest root Remove Bk from the queue Delete root of Bk (return this value); You now have a new queue made up of the forest B0, B1, …, Bk-1 Merge this queue with remainder of the original (from step 2) Run time analysis: Step 1 is O(log N), step 2 and 3 are O(1), and step 4 is O(log N). Total time = O(log N) Example: Insert 1, 2, …, 7 into empty queue and DeleteMin

Insert 1,2,…,7 1 5 7 2 3 6 4

DeleteMin 5 7 2 3 6 4

Merge 5 2 3 6 7 4

Merge 5 2 3 6 7 4

Merge 5 2 6 7 3 4

Merge 5 2 6 7 3 DONE! 4

Implementation of Binomial Queues Need to be able to scan through all trees, and given two binomial queues find trees that are same size Use array of pointers to root nodes, sorted by size Since is only of length log(N), don’t have to worry about cost of copying this array At each node, keep track of the size of the (sub) tree rooted at that node Want to merge by just setting pointers Need pointer-based implementation of heaps DeleteMin requires fast access to all subtrees of root Use First-Child/Next-Sibling representation of trees

Efficient BuildHeap for Binomial Queues Insert one at a time - O(n log n) Better algorithm: Start with each element as a singleton tree Merge trees of size 1 Merge trees of size 2 Merge trees of size 4 Complexity:

Other Mergeable Priority Queues: Leftist and Skew Heaps Leftist Heaps: Binary heap-ordered trees with left subtrees always “longer” than right subtrees Main idea: Recursively work on right path for Merge/Insert/DeleteMin Right path is always short  has O(log N) nodes Merge, Insert, DeleteMin all have O(log N) running time (see text) Skew Heaps: Self-adjusting version of leftist heaps (a la splay trees) Do not actually keep track of path lengths Adjust tree by swapping children during each merge O(log N) amortized time per operation for a sequence of M operations See Weiss for details…

Leftist Heaps An alternative heap structure that also enables fast merges Based on binary trees rather than k-ary trees What if you had networked printers or CPUs and one of them went down. Now you want to merge the priority queues! How can we do that? Here’s two naïve ways. 1st attempt: If the two trees are the same size: O(n log n) 2nd attempt: O(n) (that’s how long buildHeap takse)

Idea: Hang a New Tree 2 1 + = 5 11 9 4 6 10 13 12 14 10 ? Now, just percolate down! 2 1 How about this to get O(log n) time? Just hang the trees from a common root and percolate the root node down. This only works if we use actual trees implemented with pointers. Still it only takes log n time, right? Constant time for the hanging Log time for the percolate down. 5 11 9 4 6 10 13 12 14 10

Idea: Hang a New Tree 2 1 + = 5 11 9 4 6 10 13 12 14 10 1 Now, just percolate down! 2 ? How about this to get O(log n) time? Just hang the trees from a common root and percolate the root node down. This only works if we use actual trees implemented with pointers. Still it only takes log n time, right? Constant time for the hanging Log time for the percolate down. 5 11 9 4 6 10 13 12 14 10

Idea: Hang a New Tree 2 1 + = 5 11 9 4 6 10 13 12 14 10 1 Now, just percolate down! 2 4 How about this to get O(log n) time? Just hang the trees from a common root and percolate the root node down. This only works if we use actual trees implemented with pointers. Still it only takes log n time, right? Constant time for the hanging Log time for the percolate down. 5 11 9 ? 6 10 13 12 14 10

Idea: Hang a New Tree 2 1 + = 5 11 9 4 6 10 13 12 14 10 1 Note: we just gave up the nice structural property on binary heaps! Now, just percolate down! 2 4 How about this to get O(log n) time? Just hang the trees from a common root and percolate the root node down. This only works if we use actual trees implemented with pointers. Still it only takes log n time, right? Constant time for the hanging Log time for the percolate down. 5 11 9 6 10 13 12 14 10

Problem? = + Need some other kind of balance condition… 1 2 4 12 15 15 18 ? 1 2 4 12 15 15 18

Leftist Heaps Idea: make it so that all the work you have to do in maintaining a heap is in one small part Leftist heap: almost all nodes are on the left all the merging work is on the right Leftist heaps are a solution to that. They put all the work on the right side of the tree and most of the nodes on the left (or at least not on the right)

Random Definition: Null Path Length the null path length (npl) of a node is the number of nodes between it and a null in the tree npl(null) = -1 npl(leaf) = 0 npl(single-child node) = 0 2 1 1 Before I make this more concrete, let’s get a totally unrelated random definition that we probably will never use. Note that I’m assuming a binary tree here. Null path length is the number of nodes between a given node and a null. Npl of null is -1 npl of a leaf or a node with just one child is 0 Notice that I’m putting the null path length, NOT the values in the nodes. 1 another way of looking at it: npl is the height of complete subtree rooted at this node

Leftist Heap Properties Heap-order property parent’s priority value is  to childrens’ priority values result: minimum element is at the root Leftist property null path length of left subtree is  npl of right subtree result: tree is at least as “heavy” on the left as the right So, here are the formal properties of a leftist heap. Heap-order, of course. And, the leftist property; this means that the npl of the right child is never greater than that of the left child. Are leftist trees necessarily complete or balanced? NO. In fact, a _great_ leftist tree is a string of nodes all on the left! Are leftist trees complete? Balanced?

Leftist tree examples NOT leftist leftist leftist 2 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 Here are some training examples to help you learn. The red nodes break the leftist property for the first tree. The other two trees are leftist. every subtree of a leftist tree is leftist, comrade!

Right Path in a Leftist Tree is Short 2 If the right path has length at least r, the tree has at least 2r - 1 nodes Proof by induction Basis: r = 1. Tree has at least one node: 21 - 1 = 1 Inductive step: assume true for r’ < r. The right subtree has a right path of at least r - 1 nodes, so it has at least 2r - 1 - 1 nodes. The left subtree must also have a right path of at least r - 1 (otherwise, there is a null path of r - 3, less than the right subtree). Again, the left has 2r - 1 - 1 nodes. All told then, there are at least: 2r - 1 - 1 + 2r - 1 - 1 + 1 = 2r - 1 So, a leftist tree with at least n nodes has a right path of at most log n nodes 1 1 1 Why do we have this leftist property? Because it guarantees that the right path is really short compared to the number of nodes in the tree without being as stodgy as the heap structure property. Here’s a proof which boils down to the fact that if the left path is r long, the null path length must be at least r (otherwise somewhere along there, there’s a node with a larger right npl than left). Since the tree is complete at least to depth r, there are at least 2r - 1 nodes in the tree.

Merging Two Leftist Heaps merge(T1,T2) returns one leftist heap containing all elements of the two (distinct) leftist heaps T1 and T2 merge T1 a a recursive merge L1 R1 L1 R1 How do we merge two leftist heaps? We put the smaller root as the new root, hang its left subtree on the left. Recursively merge its right subtree and the other tree. Are we done? No. Because we haven’t ensured that the leftist property is intact. a < b T2 b b L2 R2 L2 R2

Merge Continued a a npl(R’) > npl(L1) L1 R’ R’ L1 reSo, we check if the leftist property is intact. If it isn’t we switch the right and left children. How long does this take? How much work do we do at each step? CONSTANT And, we recursively traverse the whole right path of both trees. How long are those paths? At most log n. So how much work? O(log n) Pretty cool, huh? R’ = Merge(R1, T2) constant work at each merge; recursively traverse RIGHT right path of each tree; total work = O(log n)

Operations on Leftist Heaps merge with two trees of total size n: O(log n) insert with heap size n: O(log n) pretend node is a size 1 leftist heap insert by merging original heap with one node heap deleteMin with heap size n: O(log n) remove and return root merge left and right subtrees merge Now that we have that wicked merge op. Let’s just use it to implement all the other ops. Is one node a size one leftist heap? merge

Example merge 3 5 merge 7 10 12 5 5 14 merge 3 10 12 10 12 7 8 8 8 14 ? 1 3 5 merge 7 10 12 1 ? 5 5 1 14 merge 3 10 12 10 12 7 8 8 8 Alright, let’s try an example. I’m unwinding the recursion here. I pulled a fast one merging the last two nodes. I could have reduced that to merging a node with null (which is clearly the original node) but I didn’t for convenience. Don’t _you_ do that on tests! 14 8 12

Sewing Up the Example ? ? 2 3 3 3 7 ? 7 1 7 5 1 5 5 14 14 14 10 8 10 10 8 8 No, we need to put the example back together, fixing the leftist property as we go. Are we done here? NO! The root’s right child has a higher npl than its left child! 12 12 12 Done?

Finally… 2 2 3 3 7 5 1 5 1 7 14 10 8 10 8 14 So, we swap the root’s children. Is the final tree a leftist heap? 12 12

Skew Heaps Problems with leftist heaps Solution: skew heaps extra storage for npl two pass merge (with stack!) extra complexity/logic to maintain and check npl Solution: skew heaps blind adjusting version of leftist heaps amortized time for merge, insert, and deleteMin is O(log n) worst case time for all three is O(n) merge always switches children when fixing right path iterative method has only one pass There are some problems with leftist heaps. We’ll use skew heaps to fix those problems. Motivation? Remember that we “often” get heavy right sides when we merge. So, why not just assume the right side is heavy and move it over automatically? What do skew heaps remind us of?

Merging Two Skew Heaps merge T1 a a merge L1 R1 L1 R1 a < b T2 b b Notice the old switcheroo! This merge should look very similar but simpler than the previous algorithm. L2 R2 L2 R2

Example merge 3 3 5 merge 7 5 7 10 12 5 merge 14 10 14 3 12 10 12 8 7 This happens to end up with a leftist tree and start out with leftist trees. Is that guaranteed? 5 7 8 10 14 12

Skew Heap Code void merge(heap1, heap2) { case { heap1 == NULL: return heap2; heap2 == NULL: return heap1; heap1.findMin() < heap2.findMin(): temp = heap1.right; heap1.right = heap1.left; heap1.left = merge(heap2, temp); return heap1; otherwise: return merge(heap2, heap1); } Here’s the code. I won’t go into it except to say that it is _easy_. The iterative version is a touch more intricate but also fairly easy and requires NO STACK!

Comparing Heaps Leftist Heaps Skew Heaps Binary Heaps d-Heaps Binomial Queues Leftist Heaps Skew Heaps OK, I said you were being cheated unless you got a comparison of data structures. Who can tell me some good things about each of these? Binary: simple, memory efficient, fast, can run buildHeap. cannot merge quickly. d: Faster than binary heaps. Possibly much faster in some applications. Slightly more complicated. Otherwise, all binary advantages. Leftist: supports merge quickly. Supports all other operations asymptotically quickly. Practically, extra storage, link traversals and recursion make it bigger and slower. Skew: slightly less storage, somewhat faster and simpler than leftist. NOT guaranteed fast on EVERY operation (but guaranteed amortized speed. Binomial queues? Never heard of ‘em. Read up on them in your book!

Summary of Heap ADT Analysis Consider a heap of N nodes Space needed: O(N) Actually, O(MaxSize) where MaxSize is the size of the array Pointer-based implementation: pointers for children and parent Total space = 3N + 1 (3 pointers per node + 1 for size) FindMin: O(1) time; DeleteMin and Insert: O(log N) time BuildHeap from N inputs: What is the run time? N Insert operations = O(N log N) O(N): Treat input array as a heap and fix it using percolate down Thanks, Floyd! Mergable Heaps: Binomial Queues, Leftist Heaps, Skew Heaps