Jump to content

Priority queue: Difference between revisions

m
added whitespace, centered the priority and tasks.
m (added whitespace, centered the priority and tasks.)
Line 2:
A [[wp:Priority queue|priority queue]] is somewhat similar to a [[Queue|queue]], with an important distinction: each item is added to a priority queue with a priority level, and will be later removed from the queue with the highest priority element first. That is, the items are (conceptually) stored in the queue in priority order instead of in insertion order.
 
 
'''Task:''' Create a priority queue. The queue must support at least two operations:
;Task:
# Insertion. An element is added to the queue with a priority (a numeric value).
'''Task:''' Create a priority queue.   The queue must support at least two operations:
# Top item removal. Deletes the element or one of the elements with the current top priority and return it.
#   Insertion.   An element is added to the queue with a priority (a numeric value).
#   Top item removal.   Deletes the element or one of the elements with the current top priority and return it.
 
 
Optionally, other operations may be defined, such as peeking (find what current top priority/top element is), merging (combining two priority queues into one), etc.
 
To test your implementation, insert a number of elements into the queue, each with some random priority. Then dequeue them sequentially; now the elements should be sorted by priority. You can use the following task/priority items as input data:
'''Priority''' '''Task'''
3 Clear drains
4 Feed cat
5 Make tea
1 Solve RC tasks
2 Tax return
 
To test your implementation, insert a number of elements into the queue, each with some random priority. Then dequeue them sequentially; now the elements should be sorted by priority. You can use the following task/priority items as input data:
The implementation should try to be efficient. A typical implementation has O(log n) insertion and extraction time, where n is the number of items in the queue. You may choose to impose certain limits such as small range of allowed priority levels, limited capacity, etc. If so, discuss the reasons behind it.
 
Then dequeue them sequentially; now the elements should be sorted by priority.
 
You can use the following task/priority items as input data:
'''Priority''' '''Task'''
══════════ ════════════════
3 Clear drains
4 Feed cat
5 Make tea
1 Solve RC tasks
2 Tax return
 
 
The implementation should try to be efficient.   A typical implementation has O(log n) insertion and extraction time,   where   '''n'''   is the number of items in the queue. You may choose to impose certain limits such as small range of allowed priority levels, limited capacity, etc. If so, discuss the reasons behind it.
 
You may choose to impose certain limits such as small range of allowed priority levels, limited capacity, etc.   If so, discuss the reasons behind it.
<br><br>
 
=={{header|Ada}}==
Cookies help us deliver our services. By using our services, you agree to our use of cookies.