Nella teoria delle code, una coda di priorità è una struttura dati astratta, simile ad una coda o ad una pila, ma diversa da queste in quanto ogni elemento inserito all'interno della coda possiede una sua "priorità". In una coda di priorità, ogni elemento avente priorità più alta, viene inserito prima rispetto ad un elemento avente priorità più bassa. In particolare, l'elemento con priorità più alta si trova in testa alla coda, quello con priorità più bassa si troverà, appunto, in coda.
Operazioni
[modifica | modifica wikitesto]Le code di priorità devono, necessariamente, supportare tali operazioni:
- insert(elemento e, chiave k): Tale operazione inserisce l'elemento e nella coda in base alla sua priorità definita dalla chiave k.
- findMin(): Tale operazione restituisce l'elemento della coda avente priorità più bassa, senza eliminarlo.
- removeMin(): Tale operazione elimina l'elemento della coda avente priorità più bassa.
- findMax(): Tale operazione restituisce l'elemento della coda avente priorità più alta, senza eliminarlo.
- removeMax(): Tale operazione restituisce l'elemento della coda avente priorità più alta.
Implementazione
[modifica | modifica wikitesto]Per implementare una coda di priorità viene spesso utilizzato l'heap binario in quanto tale struttura permette l'inserimento e l'eliminazione in un tempo di O(logn) nel caso peggiore. È possibile anche utilizzare heap binomiali o heap di Fibonacci per rendere più efficaci determinate operazioni.[1] Per via della naturale implementazione delle code di priorità con gli heap queste spesso vengono chiamate in letteratura anche heap rovesciato. Intendendo con heap rovesciato uno heap che ha nella radice l'elemento minore dell'albero, e non il maggiore, e nel quale ogni figlio è maggiore del padre cioè al contrario di uno heap standard.
Applicazioni
[modifica | modifica wikitesto]Le code a priorità vengono largamente impiegate in informatica e in generale nell'ambito dell'elaborazione di dati (comprese le telecomunicazioni e i circuiti elettronici digitali) per eseguire operazioni complesse quali:
- ordinamento di elementi sulla base della loro priorità
- ottimizzazioni nell'accesso a risorse condivise, soprattutto in caso di accessi concorrenti e in congestione
- gestione di attività a schedulazione
- algoritmi euristici di ricerca
Relazione tra coda di priorità ed algoritmi di ricerca
[modifica | modifica wikitesto]Una coda di priorità viene spesso accoppiata agli algoritmi di ricerca. Nella seguente tabella, per ogni algoritmo, viene indicato l'implementazione migliore e i vari costi:
Algoritmo | Implementazione con code di priorità | Caso migliore | Caso medio | Caso peggiore |
---|---|---|---|---|
Smoothsort | Heap di Leonardo | |||
Selection sort | Array non ordinato | |||
Insertion Sort | Array ordinato | |||
Tree sort | Albero binario di ricerca | |||
Heapsort | Heap |
Note
[modifica | modifica wikitesto]- ^ (EN) Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest e Clifford Stein, Chapter 20: Fibonacci Heaps, in Introduction to Algorithms, MIT Press and McGraw-Hill, 2001, pp. 476–497, 518, ISBN 0-262-03293-7.
Bibliografia
[modifica | modifica wikitesto]- Camil Demetrescu, Irene Finocchi, Giuseppe Italiano, Algoritmi e strutture dati, McGraw-Hill, 2004. ISBN 88-386-6161-8. Capitolo 8: Code di priorità, pp.187-206.
- Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest, and Clifford Stein. Introduction to Algorithms, Second Edition. MIT Press and McGraw-Hill, 2001
Collegamenti esterni
[modifica | modifica wikitesto]- (EN) Denis Howe, priority queue, in Free On-line Dictionary of Computing. Disponibile con licenza GFDL