Heap (structură de date)


În informatică , un heap este o structură de date specializată de tip arbore care satisface proprietatea heap : dacă B este un nod copil al nodului A , atunci key( A ) ≥ key( B ). Rezultă că elementul cu cea mai mare cheie este întotdeauna nodul rădăcină al heap-ului, așa că uneori astfel de grămezi sunt numite max-heaps (în mod alternativ, dacă comparația este inversată, cel mai mic element va fi întotdeauna nodul rădăcină, astfel de grămezi sunt numite min-heaps ). Nu există nicio restricție cu privire la câte noduri copil are fiecare nod heap, deși în practică acest număr nu este de obicei mai mare de doi. Heap-ul este cea mai eficientă implementare a unui tip de date abstract numit coadă de prioritate . Heaps-urile sunt cruciale în unii algoritmi de grafice eficienți , cum ar fi algoritmul lui Dijkstra pentru d-heaps și heapsort .  

Structura de date heap nu trebuie confundată cu conceptul de heap în alocare dinamică a memoriei . Termenul a fost folosit pentru prima dată în mod specific pentru structurile de date. Unele limbaje de programare populare timpurii, cum ar fi LISP , au oferit alocarea dinamică a memoriei folosind structura de date „heap”, care și-a dat numele cantității de memorie alocată. [1] .

Heap-urile sunt de obicei implementate ca matrice, ceea ce elimină nevoia de pointeri între elementele sale.

Următoarele operații sunt de obicei efectuate pe grămezi:

Opțiuni

Compararea estimărilor teoretice ale variantelor

Mai jos sunt estimări ale complexității în timp a calculelor pentru operațiuni pe anumite tipuri de heaps. [1] În cazul în care o valoare este marcată cu un asterisc, estimarea se bazează pe analiza amortizarii (cel mai rău moment), în caz contrar, estimarea este un caz obișnuit cel mai rău. O(F) oferă o limită superioară asimptotică, iar Θ(F) este o estimare exactă asimptotic (vezi notația „O” mare și „o” mic ). Numele operațiunilor sunt alese pentru min-heap.

(*) Timp de amortizare
(**) Unde n este dimensiunea celui mai mare heap

Rețineți că „Coda lui Brodal” este o implementare a unei cozi de așteptare paralele dezvoltată de un grup condus de Gert Brodal. [3]

Aplicație

Structurile de date heap au multe utilizări.

Un heap binar complet și aproape complet poate fi reprezentat într-un mod foarte eficient folosind o matrice de index . Primul (sau ultimul) element va conține rădăcina. Următoarele două elemente ale matricei conțin nodurile copil ale rădăcinii. Următoarele patru elemente conțin patru copii din două noduri care sunt copii ai rădăcinii etc.. Astfel, copiii nodului de nivel nvor fi localizați la poziții 2nși 2n+1pentru un tablou indexat din unul, sau la poziții 2n+1și 2n+2pentru un tablou indexat . de la zero. Acest lucru vă permite să vă deplasați în sus sau în jos în arbore făcând calcule simple ale indexului matricei. Echilibrarea heap se face prin rearanjarea elementelor care nu sunt în ordine. Deoarece putem construi un heap folosind o matrice fără memorie suplimentară (pentru noduri, de exemplu), putem folosi heapsort pentru a sorta matricea în loc.

Implementări

Vezi și

Note

  1. 1 2 3 Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest (1990): Introduction to algorithms. MIT Press / McGraw-Hill.
  2. Iacono, John (2000), Limite superioare îmbunătățite pentru grămezi de perechi , Proc. Al 7-lea Atelier scandinav de teoria algoritmului , vol. 1851, Lecture Notes in Computer Science, Springer-Verlag, p. 63–77 , DOI 10.1007/3-540-44985-X_5 
  3. A Parallel Priority Queue with Constant Time Operations , < http://www.ceid.upatras.gr/faculty/zaro/pub/jou/J9-JPDC-pq.pdf > Arhivat 26 iulie 2011 la Wayback Machine 
  4. Frederickson, Greg N. (1993), An Optimal Algorithm for Selection in a Min-Heap , Information and Computation , vol. 104, Presa Academică, p. 197–214, doi : 10.1006/inco.1993.1030 , < http://ftp.cs.purdue.edu/research/technical_reports/1991/TR%2091-027.pdf > Arhivat 3 decembrie 2012 la Wayback Machine 
  5. Python heapq . Consultat la 31 mai 2011. Arhivat din original la 18 octombrie 2012.
  6. Perl Heap