Priority Queues and Heaps Flashcards
What is a priority queue and what are it’s operations?
data:image/s3,"s3://crabby-images/e1c13/e1c136035e95a39062c7e62e75a18c16db48d726" alt=""
What are the applications of a priority Queue?
Hospital emergency room
Event-Driven simulations
data:image/s3,"s3://crabby-images/905d2/905d2e1930dc1c61b4c41a694f3f62f7e9248fbf" alt=""
How does a priority queue compare to a queue?
data:image/s3,"s3://crabby-images/dea98/dea98ea66f64e0355428ade9b12cde601a34802f" alt=""
What are the implementations of a priority queue, what are their speeds of operations and which is the best?
- Array or LinkedList
- order by priority (highest priority item first)
- DeleteMax is a remove-from-front(cost O(1))
- Insert is an ordered insert(cost O(n)
- order by priority (highest priority item first)
- Binary search tree (BST) The highest priority item is in the rightmost descendant of the root
- DeleteMax and Insert are O(n) (unless you use some sort of balanced tree (O(n)).
- Best-> a Heap: A binary tree - but not a BST - stored in an array
- DeleteMax and Insert are O(log n)
What is the definition of a full tree?
data:image/s3,"s3://crabby-images/4053f/4053f2bc02b2707e4b422975555b1cb32c24535b" alt=""
Define a complete tree
data:image/s3,"s3://crabby-images/ef6ab/ef6ab4fc0202b87f9786a14438531ef51b28860c" alt=""
What is the definition of heap ordered?
data:image/s3,"s3://crabby-images/0c937/0c93732a04fac9886cd0ed5cbaca8a297d011f2a" alt=""
data:image/s3,"s3://crabby-images/f59ac/f59ac7af1a6a78e92b9ab8fc2d510f275fe97f25" alt=""
data:image/s3,"s3://crabby-images/a6101/a61014fd0052473bfaec1428a68d0d89cd8c218b" alt=""
What is the definition of a heap
data:image/s3,"s3://crabby-images/47a75/47a75ba27e20e3b0a11e70cf5b066861a8fb3b81" alt=""
In general how is an array used to implement a heap?
data:image/s3,"s3://crabby-images/b8149/b8149ab7ac0d9a1b1183f920fe0c0cd259c08364" alt=""
With no pointers, how do we find a node’s children?
data:image/s3,"s3://crabby-images/35a45/35a454deda7c472d513c5f733ee06a5996aa7206" alt=""
If 35 is stored in array index 5:
- What is the index of the left child?
- right child?
- What is the index of it’s parent?
data:image/s3,"s3://crabby-images/c5b62/c5b62f1841c58472ed53d3a575f75a54c9035e33" alt=""
data:image/s3,"s3://crabby-images/2cdac/2cdacc53a10251ac712d9e77e578e7975d5ac1fe" alt=""
data:image/s3,"s3://crabby-images/31034/3103445bc014ca0de4b1a4ebe06597069ec69dab" alt=""
In general how do heap insertions work?
- First, place the new item in heap[heapSize] and increment heap size.
- The heap may not be heap ordered now (new item might be larger than parent)
- We need to sift up the new item towards the root
- repeatedly exchange the new item with it’s parent until either:
- It’s parent is larger than the new item, or
- The new item is the root
- repeatedly exchange the new item with it’s parent until either:
data:image/s3,"s3://crabby-images/30546/305466a6f4f0ae0bb049655c405ae708e9c42944" alt=""
data:image/s3,"s3://crabby-images/c27aa/c27aab66c8fa76d45a3db0090ca4f43e736fab8f" alt=""
data:image/s3,"s3://crabby-images/06ea5/06ea5dc672437cea2c5bfe2b3df87de0d384eb7d" alt=""
data:image/s3,"s3://crabby-images/0ee70/0ee70f7df8386ece0af2f7b7e2f848424a8588c5" alt=""
What is the code for insert (including the priority queue class)?
data:image/s3,"s3://crabby-images/5cd1a/5cd1addd01126fb4b52f05ff3807f5fc428ab495" alt=""
What is the code for siftUp?
data:image/s3,"s3://crabby-images/2d38a/2d38a419536999c5ed92aa628f2cf0d1365dc5e0" alt=""
What is the code for swap?
data:image/s3,"s3://crabby-images/91b9f/91b9fe1be1ff21d5cb4e6f843aa85d446d5054d2" alt=""
In general how doe DeleteMax work?
- Save the item in the roon (heap[0]), because it has the highest priority, so we will want to return it.
- Take the item I in heap[heapSize-1] (bottom of the heap) and place it in the root, and decrement heapSize.
- We must restore heap order in the heap: item I (which we just placed in the root) may be less than one or both of its children since an item fomr the bottom of the heap will have a low priority.
- To restore heap order: sift down the root (repeatedly swap I with the larger of it’s two children (if it has two) or it’s sole child (if only one) until either:
- I is larger than it’s two children(or than it’s sole and only child) or
- I has no children
DeleteMax the following heap
data:image/s3,"s3://crabby-images/602d5/602d548499b0d447c67546d94cca414cf314b20e" alt=""
data:image/s3,"s3://crabby-images/fee53/fee539df1e081d3b893f53fa134ad7488ceb8d43" alt=""
data:image/s3,"s3://crabby-images/fef97/fef97a174fbe3f8db50b29cda8beabfa06a35c75" alt=""
data:image/s3,"s3://crabby-images/c3856/c3856f5c69cdaeea934d32ec22725bca128d7a9c" alt=""
data:image/s3,"s3://crabby-images/7543a/7543a1897df1e2307d72b490ef51b18a680c9eae" alt=""
data:image/s3,"s3://crabby-images/80ab7/80ab7114afea65c9f45f6eb3741217c8ad4d86ed" alt=""
data:image/s3,"s3://crabby-images/4e082/4e0821b3cc1bbd8201008d21821fde092cb27463" alt=""
data:image/s3,"s3://crabby-images/b0aa0/b0aa08e13444811d4ad952fa6aeb9596bca231b0" alt=""
What is the code for deleteMax?
data:image/s3,"s3://crabby-images/04ae0/04ae04c149020410e7086d9ddf3e109c9136a746" alt=""
What is the code for siftDown?
data:image/s3,"s3://crabby-images/a1733/a173352150dba2f1fffe483f0cb92f3e7ac2c617" alt=""
What is the run time of insert and deleteMax?
data:image/s3,"s3://crabby-images/a881b/a881b3cfb255b0dfc23221fe71ea77b6c61b406d" alt=""