Introsort - Introsort
Třída | Algoritmus řazení |
---|---|
Datová struktura | Pole |
Nejhorší případ výkon | Ó(n log n) |
Průměrný výkon | Ó(n log n) |
Introsort nebo introspektivní řazení je hybridní třídicí algoritmus který poskytuje rychlý průměrný výkon a (asymptoticky) optimální výkon v nejhorším případě. Začíná to quicksort, přepne se na heapsort když hloubka rekurze překročí úroveň na základě ( logaritmus z) počet prvků, které jsou tříděny, a přepne se na třídění vložení když je počet prvků pod určitou prahovou hodnotou. To kombinuje dobré části těchto tří algoritmů s praktickým výkonem srovnatelným s quicksortem na typických souborech dat a nejhorším případě Ó (n log n) runtime kvůli druhu haldy. Jelikož tři použité algoritmy jsou druhy porovnání, je to také druh srovnání.
Introsort vynalezl David Musser v Musser (1997), ve kterém také představil introselect hybrid algoritmus výběru na základě rychlý výběr (varianta rychlého třídění), která spadá zpět do medián mediánů a poskytuje tak nejhorší lineární složitost, která je optimální. Oba algoritmy byly zavedeny za účelem poskytnutí obecné algoritmy pro Standardní knihovna C ++ který měl jak rychlý průměrný výkon, tak optimální výkon v nejhorším případě, což umožnilo zpřísnit výkonnostní požadavky.[1] Introsort je na místě a ne stabilní.[2]
Pseudo kód
Pokud je implementace a rozdělení oddílů funkcí typu popsaného v quicksort článku jsou k dispozici, introsort lze stručně popsat jako
postup sort (A: array): nechat maxdepth = ⌊log (length (A)) ⌋ × 2 introsort (A, maxdepth)postup introsort (A, maxdepth): n ← délka (A) -li n ≤ 1: vrátit se // základní případ jinak pokud maxdepth = 0: heapsort (A) jiný: p ← oddíl (A) // předpokládejme, že tato funkce provede výběr otočného čepu, p je konečná poloha otočného čepu introsort (A [0: p-1], maxdepth - 1) introsort (A [p + 1: n], maxdepth - 1)
Faktor 2 v maximální hloubce je libovolný; lze jej vyladit pro praktický výkon. A[i:j] označuje pole plátek položek i na j.
Analýza
V quicksortu je jednou z kritických operací volba pivot: prvek, kolem kterého je seznam rozdělen. Nejjednodušším algoritmem výběru otočného čepu je převzetí prvního nebo posledního prvku seznamu jako otočného čepu, což způsobí špatné chování v případě seřazeného nebo téměř tříděného vstupu. Niklaus Wirth Varianta používá prostřední prvek k prevenci těchto výskytů, degeneruje na O (n2) pro vytvořené sekvence. Algoritmus otočného výběru střední hodnoty ze 3 přebírá střední hodnotu prvního, středního a posledního prvku seznamu; i když to funguje dobře na mnoha vstupech ze skutečného světa, je stále možné vymyslet a medián 3 vraha seznam, který způsobí dramatické zpomalení rychlého řazení založeného na této technice pivotního výběru.
Musser uvedl, že na sekvenci zabijáku se střední hodnotou 3 000 100 prvků byla doba chodu introsortu 1/200 doby rychlého řazení se střední hodnotou 3. Musser také zvažoval účinek na mezipaměti z Sedgewick je zpožděné malé třídění, kde jsou na konci tříděny malé rozsahy v jednom průchodu třídění vložení. Uvedl, že by to mohlo zdvojnásobit počet chyb v mezipaměti, ale že jeho výkon s oboustranné fronty byl výrazně lepší a měl by být zachován pro knihovny šablon, částečně proto, že zisk v jiných případech z okamžitého provádění druhů nebyl velký.
Implementace
Introsort nebo nějaká varianta se používá v řadě standardní knihovna třídicí funkce, včetně některých C ++ řazení implementace.
Červen 2000 SGI C ++ Standardní knihovna šablon stl_algo.h implementace nestabilní druh používá přístup Musser introsort s hloubkou rekurze k přepnutí na heapsort předaný jako parametr, výběr střední hodnoty ze 3 pivotů a Knuthovo finální třídění vložení pro oddíly menší než 16.
The Knihovna GNU Standard C ++ je podobný: používá introsort s maximální hloubkou 2 × log2 n, následovaný znakem třídění vložení na oddílech menších než 16.[3]
The Microsoft .NET Framework Knihovna tříd, počínaje verzí 4.5 (2012), používá introsort místo jednoduchého quicksortu.[4]
Jít používá introsort s malou úpravou: pro plátky 12 nebo méně prvků používá Shellsort namísto třídění vložení a pokročilejší medián tří mediánů tří otočného výběru pro rychlý výběr.
Reference
Všeobecné
- Musser, David R. (1997). "Introspektivní algoritmy řazení a výběru". Software: Praxe a zkušenosti. 27 (8): 983–993. doi:10.1002 / (SICI) 1097-024X (199708) 27: 8 <983 :: AID-SPE117> 3.0.CO; 2- #.CS1 maint: ref = harv (odkaz)
- Niklaus Wirth. Algoritmy a datové struktury. Prentice-Hall, Inc., 1985. ISBN 0-13-022005-1.