V informatice je halda specializovaná datová struktura stromového typu , která splňuje vlastnost haldy : pokud B je podřízený uzel uzlu A , pak key( A ) ≥ key( B ). Z toho vyplývá, že prvek s největším klíčem je vždy kořenový uzel haldy, takže někdy se takové haldy nazývají max-heaps (alternativně, pokud je srovnání obráceno, nejmenším prvkem bude vždy kořenový uzel, takové haldy se nazývají min-hromady ). Neexistuje žádné omezení, kolik podřízených uzlů má každý uzel haldy, i když v praxi tento počet obvykle není větší než dva. Halda je nejúčinnější implementací abstraktního datového typu nazývaného prioritní fronta . Hromady jsou klíčové v některých efektivních grafových algoritmech , jako je Dijkstrův algoritmus pro d-hromady a heapsort .
Struktura dat haldy by neměla být zaměňována s konceptem haldy v dynamické alokaci paměti . Termín byl poprvé použit speciálně pro datové struktury. Některé rané populární programovací jazyky, jako je LISP , poskytovaly dynamickou alokaci paměti pomocí datové struktury „haldy“, která dala jméno přidělenému množství paměti. [1] .
Haldy jsou obvykle implementovány jako pole, což eliminuje potřebu ukazatelů mezi jejími prvky.
Na hromadách se obvykle provádějí následující operace:
Níže jsou uvedeny odhady časové složitosti výpočtů pro operace na určitých typech hald. [1] Je- li hodnota označena hvězdičkou, je odhad založen na analýze amortizace (nejhorší doba), jinak je odhad běžný nejhorší případ. O(F) udává asymptotickou horní hranici a Θ(F) je asymptoticky přesný odhad (viz označení „O“ velké a „o“ malé ). Názvy operací jsou vybrány pro min-hromadu.
(*) Doba amortizace
(**) Kde n je velikost největší haldy
Všimněte si, že "Brodalova fronta" je implementací paralelní prioritní fronty vyvinuté skupinou vedenou Gertem Brodalem. [3]
Datové struktury haldy mají mnoho využití.
Kompletní a téměř kompletní binární haldu lze reprezentovat velmi efektivním způsobem pomocí indexového pole . První (nebo poslední) prvek bude obsahovat kořen. Další dva prvky pole obsahují podřízené uzly kořene. Další čtyři prvky obsahují čtyři potomky ze dvou uzlů, které jsou potomky kořene atd. Potomci uzlu úrovně nbudou tedy umístěni na pozicích 2na 2n+1pro pole indexované z jednoho nebo na pozicích 2n+1a 2n+2pro pole indexované od nuly. To vám umožňuje pohybovat se ve stromu nahoru nebo dolů pomocí jednoduchých výpočtů indexu pole. Vyvažování haldy se provádí přeskupením prvků, které jsou mimo provoz. Protože můžeme vytvořit haldu pomocí pole bez další paměti (například pro uzly), můžeme použít heapsort k seřazení pole na místě.
Datové struktury | |
---|---|
Seznamy | |
Stromy | |
Počítání | |
jiný |
operačních systémů | Aspekty|||||
---|---|---|---|---|---|
| |||||
Typy |
| ||||
Jádro |
| ||||
Řízení procesů |
| ||||
Správa a adresování paměti |
| ||||
Nástroje pro načítání a inicializaci | |||||
Shell | |||||
jiný | |||||
Kategorie Wikimedia Commons Wikibooks Wikibooks |