250 likes | 471 Views
Algoritmul HeapSort. HeapSort este unul din algoritmii de sortare foarte performanti, fiind de clasa O(N · log 2 N) Mai este cunoscut sub denumirea de “sortare prin metoda ansamblelor”
E N D
Algoritmul HeapSort HeapSort este unul din algoritmii de sortare foarte performanti, fiind de clasa O(N·log2N) Mai este cunoscut sub denumirea de “sortare prin metoda ansamblelor” Desi nerecursiv, este aproape la fel de performant ca si algoritmii de sortare recursivi (QuickSort fiind cel mai cunoscut) HeapSort este un algoritm de sortare “in situ”, adica nu necesita structuri de date suplimentare, ci sortarea se face folosind numai spatiul de memorie al tabloului ce trebuie sortat Exista si implementari HeapSort care nu sunt “in situ” Algoritmul HeapSort
Algoritmul HeapSort • Algoritmul se aseamana, in unele privinte, cu sortarea prin selectie (SelSort) • La fiecare pas, cel mai mic element din tablou este gasit si mutat in spatele tabloului, fiind ignorat de pasii urmatori, care vor continua pe restul tabloului • Diferenta fata de SelSort este ca pasii urmatori ai algoritmului vor depune un efort mai mic (chiar mult mai mic) pentru a depista minimul din tabloul ramas • Fiecare pas al algoritmului are darul de a usura sarcina pasilor ce urmeaza, ceea ce duce la performanta foarte buna a algoritmului Algoritmul HeapSort
Algoritmul HeapSort • Gasirea minimului din tablou, operatie ce are loc la fiecare pas, se bazeaza pe aducerea tabloului la forma de ansamblu • Un ansamblu este un sir Ai (i = 1 … N) care indeplineste urmatoarele conditii pentru fiecare i: • Ai ≤ A2·i • Ai≤ A2·i+1 • Evident, pentru valori ale lui i mai mari decat N/2 nu se pune problema indeplinirii conditiilor de mai sus Algoritmul HeapSort
Algoritmul HeapSort • Orice tablou poate fi transformat usor intr-un arbore binar Index: 1 2 3 4 5 6 7 8 9 A: A1 A2 A3 A4 A5 A6 A7 A8 A9 A1 A2 A3 A4 A5 A6 A7 A8 A9 Algoritmul HeapSort
Algoritmul HeapSort • Daca tabloul era ansamblu, se observa ca arborele binar obtinut indeplineste urmatoarea conditie: “fiecare nod are cheia mai mare sau egala cu a tatalui sau”. • Astfel, A2 si A3 sunt mai mari sau egale cu A1, A4 si A5 sunt mai mari sau egale cu A2, s. a. m. d. • Dar A1 este radacina arborelui binar, ceea ce inseamna ca A1 trebuie sa fie elementul minim al tabloului • Deci intr-un ansamblu, elementul minim se afla intotdeauna pe prima pozitie • In cadrul algoritmului HeapSort, daca la fiecare pas aducem tabloul pe care lucram la forma unui ansamblu inseamna ca am localizat in acelasi timp si minimul din tablou Algoritmul HeapSort
Algoritmul HeapSort • Aducerea unui tablou la forma de ansamblu se face urmarind situatii cum este cea descrisa mai jos: • Daca nu este indeplinita una din conditiile Ai ≤ A2·i si Ai ≤ A2·i+1 atunci se va interschimba Ai cu minimul dintre A2·i si A2·i+1 • Elementele astfel interschimbate vor indeplini conditia de ansamblu • Pentru o eficienta cat mai mare, urmarirea acestui gen de situatii trebuie facuta de la dreapta la stanga, in caz contrar fiind nevoie de reveniri repetate chiar si dupa ce o situatie de neconcordanta a fost rezolvata Index: 1 … i … 2·i 2·i+1 … N A: A1 … Ai … A2·i A2·i+1 … AN Algoritmul HeapSort
Algoritmul HeapSort • Vom studia, pas cu pas, modul in care un tablou oarecare poate fi transformat in ansamblu • Aceasta transformare se va aplica la fiecare pas in cadrul algoritmului HeapSort, pe un tablou din ce in ce mai mic (deoarece dupa fiecare pas, primul element al tabloului, care este elementul minim, va fi eliminat si “pus la pastrare”, algoritmul continuand pe restul tabloului) • Pentru simplitate, vom lucra pe reprezentarea sub forma de arbore a tabloului: Index: 1 2 3 4 5 6 7 8 9 A: 9 5 1 8 6 4 3 7 2 Algoritmul HeapSort
Algoritmul HeapSort 9 • Problema se pune numai pentru noduri neterminale • Localizam cel mai de jos nod neterminal, si in caz ca sunt mai multe astfel de noduri, il consideram pe cel mai din dreapta – acesta este 8 • Cum 8 are fiii 7 si 2 si este mai mare decat ambii, se va interschimba cu cel mai mic dintre ei, adica cu 2 5 1 8 6 4 3 7 2 Algoritmul HeapSort
Algoritmul HeapSort 9 • Urmatorul nod neterminal este 1 (nodul 5 este pe acelasi nivel, dar il alegem intotdeauna pe cel mai din dreapta in astfel de cazuri) • Nodul 1 este mai mic decat fiii sai, deci nu va face obiectul vreunei interschimbari • Trecand la nodul 5, acesta nu indeplineste conditiile, ca atare va fi interschimbat cu cel mai mic fiu al sau, anume 2 5 1 2 6 4 3 7 8 Algoritmul HeapSort
Algoritmul HeapSort 9 • Inainte de a trece la noul nod neterminal, verificam ca ultimul nod interschimbat (5) sa indeplineasca conditia referitoare la fiii sai (7 si 8) – se observa ca o indeplineste • Noul nod neterminal este 9 • Acesta nu indeplineste conditiile, fiind mai mare si decat 2 si decat 1, ca atare, 9 va fi interschimbat cu cel mai mic, deci cu 1 2 1 5 6 4 3 7 8 Algoritmul HeapSort
Algoritmul HeapSort 1 • S-ar putea ca ultimul nod interschimbat (9) inca sa nu indeplineasca conditiile referitoare la fiii sai, in noua sa locatie • 9 fiind mai mare si decat 4 si decat 3, se va interschimba cu 3 (cel mai mic) • Astfel de interschimbari repetate vor avea loc pana cand 9 ajunge pe un nivel pe care fiii sai sunt mai mari sau egali cu el (sau pe un nivel unde nu mai are fii) 2 9 5 6 4 3 7 8 Algoritmul HeapSort
Algoritmul HeapSort 1 • 9 a ajuns pe un nivel terminal (nu mai are fii) deci nu mai continuam in jos • In acest moment, tabloul a ajuns la forma de ansamblu, fiecare nod avand cheia mai mica sau egala decat cheile fiilor sai • Cel mai mic element al tabloului a ajuns pe post de radacina • Interschimbam radacina cu ultimul element al tabloului, adica 1 cu 8 2 3 5 6 4 9 7 8 Algoritmul HeapSort
Algoritmul HeapSort 8 • Elementul minim (1) se elimina si se adauga la un tablou auxiliar, initial vid, care va contine la final elementele sortate • Acesta a fost primul pas al algoritmului de sortare HeapSort • Vom studia inca un pas al algoritmului 2 3 5 6 4 9 7 1 Algoritmul HeapSort
Algoritmul HeapSort • Situatia actuala este prezentata mai jos: 8 2 3 5 6 4 9 7 1 Index: 1 2 3 4 5 6 7 8 9 Tablou auxiliar: 1 - - - - - - - - Algoritmul HeapSort
Algoritmul HeapSort 8 • Nodurile neterminale considerate sunt, in ordine: 5, 3, 2 si 8 • Datorita pasului anterior, nodurile 5, 3 si 2 indeplinesc conditiile referitoare la fiii lor (pasii anteriori au usurat sarcina pasului curent) • Nodul 8 nu indeplineste conditiile, deci va fi interschimbat cu 2 2 3 5 6 4 9 7 Algoritmul HeapSort
Algoritmul HeapSort 2 • Nici in noua locatie, 8 nu indeplineste conditiile, ca urmare va fi interschimbat cu 5 8 3 5 6 4 9 7 Algoritmul HeapSort
Algoritmul HeapSort 2 • Nici in noua locatie, 8 nu indeplineste conditiile, ca urmare va fi interschimbat cu 7 5 3 8 6 4 9 7 Algoritmul HeapSort
Algoritmul HeapSort 2 • 8 nu mai are fii, deci ne oprim aici • Tabloul a devenit ansamblu, cel mai mic element din tablou ajungand pe post de radacina • Interschimbam radacina cu ultimul element al tabloului, adica 2 cu 8 5 3 7 6 4 9 8 Algoritmul HeapSort
Algoritmul HeapSort 8 • Elementul minim (2) se elimina si se adauga la tabloul auxiliar • Acesta a fost al doilea pas al algoritmului de sortare HeapSort 5 3 7 6 4 9 2 Algoritmul HeapSort
Algoritmul HeapSort • Situatia actuala este prezentata mai jos: 8 5 3 7 6 4 9 2 Index: 1 2 3 4 5 6 7 8 9 Tablou auxiliar: 1 2 - - - - - - - Algoritmul HeapSort
Algoritmul HeapSort • Repetand algoritmul de transformare a tabloului in ansamblu si eliminand dupa fiecare pas elementul minim obtinut (radacina arborelui), vom obtine in tabloul auxiliar elementele ordonate • La fiecare pas, tabloul scade cu un element • De asemenea, se poate observa ca la fiecare pas, in afara de radacina arborelui, toate celelalte elemente indeplinesc deja conditia de ansamblu datorita pasului anterior • Rezulta ca sarcina fiecarui pas nou este mult usurata de activitatea pasului/pasilor precedenti, ceea ce face ca algoritmul HeapSort sa fie foarte performant Algoritmul HeapSort
Algoritmul HeapSort • Algoritmul HeapSort este cel mai slab algoritm de clasa O(N·log2N) • Este mai slab (dar nu cu mult) decat algoritmii din familia QuickSort, dar are marele avantaj fata de acestia ca nu este recursiv • Algoritmii recursivi ruleaza rapid, dar consuma o mare cantitate de memorie, ceea ce nu le permite sa sorteze tablouri de dimensiuni oricat de mari • HeapSort este un algoritm care “impaca” viteza cu consumul relativ mic de memorie Algoritmul HeapSort