Coda di priorità

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

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

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

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

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

  1. ^ (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

  • 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

  Portale Informatica: accedi alle voci di Wikipedia che trattano di informatica