Rikiavimo algoritmas
Straipsnis iš Vikipedijos, laisvosios enciklopedijos.
Rikiavimo algoritmas - algoritmas, dėstantis duomenis tam tikra tvarka. Algoritmo darbas priklauso nuo duomenų tvarkos apibrėžimo, duomenų struktūros, rikiuojamų, atminties panaudojimo rikiavimui, duomenų pateikimo vienalaikiškumo, eiliškumo, kitų veiksnių.
Turinys |
[taisyti] Skirstymas
Rikiavimo algoritmai gali būti skirstomi keliais būdais:
- Pagal naudojamą atmintį. Priklausomai nuo to, ar naudoja tik vidinę kompiuterio atmintį, ar jiems reikia ir išorinės, rikiavimo algoritmai skirstomi į vidinio rikiavimo ir išorinio rikiavimo. Taip pat algoritmus galima skirstyti ir pagal reikiamos atminties kiekį (nereikia visai; reikia tik rodyklėms; papildomai reikia tiek, kiek yra duomenų).
- Pagal stabilumą. Stabilūs algoritmai nekeičia lygių elementų tvarkos, o nestabilūs algoritmai to negarantuoja.
- Pagal sudėtingumą.
[taisyti] Lygiagretieji algoritmai
Naudojant daugiaprocesorinį kompiuterį ar paskirstytą kompiuterių tinklą galima pasiekti ir dar geresnių rezultatų. Geriausiu atveju pasiekiamas sudėtingumas O ((log N)²).
[taisyti] Rikiavimo algoritmų sudėtingumas
Dažnai greitam darbui su duomenimis būtina duomenis susirikiuoti, bet esant dideliems duomenų kiekiams labai svarbu ir pačio rikiavimo algoritmo sudėtingumas - atlikimo greičio (arba tam tikrų, pasirinktų operacijų skaičiaus) priklausomybė nuo duomenų kiekio.
Algoritmų analizėje duomenų rikiavimo problema laikoma pačia svarbiausia, nes tai viena dažniausiai pasitaikančių operacijų programavime. Efektyvus rikiavimo algoritmo pasirinkimas gali turėti netgi lemiamą įtaką programos vykdymo spartai didėjant duomenų kiekiui.
[taisyti] Algoritmų sudėtingumų lentelė
Algoritmas | Blogiausias | Tikėtinas | Geriausias | Pastabos (stabilumas, atmintis, išorinis/vidinis) |
---|---|---|---|---|
Skaitmeninis radixsort |
O(2d N) | O(2d N) | O(2d N) | Tik skaitmeninėms teigiamoms duomenų reikšmėms, kur d yra skaitmenų sk. Reikalauja papildomos atminties |
Greitojo rikiavimo (quicksort) | O(N2) | O(N log N) | O(N log N) | Beveik nenaudoja papildomos atminties |
Kombinuotas | O(N log N) | O(N (log N)²) | ||
Krūvos (heapsort) | O(N log N) | O(N log N) | O (N log N) | Nestabilus, nenaudoja papildomos atminties |
Šelo (Shell sort) | O(N2) | O(N1,2) | O(N) | |
Sąlajos (mergesort) |
O(N log N) | O(N log N) | O(N log N) | Stabilus, naudoja papildomą atmintį. Tinka, kai iš karto galime nuskaityti nevisus duomenis į operatyvią atmintį |
Burbulo (bubble) | O(N2) | O(N2) | O(N) | Nenaudoja papildomos atminties |
Įterpimo (insertion) | O(N2) | O (N2) | O(N) | Stabilus |
Išrinkimo (selection) | O(N2) | O(N2) | O(N2) |
[taisyti] Nuorodos
- Įvairūs rikiavimo algoritmai
- Išorinis rikiavimas (external sorting)
Dar žr. Klasifikavimo algoritmai