Třídění sloučení a vložení - Merge-insertion sort
v počítačová věda, sloučení a vložení nebo Ford-Johnsonův algoritmus je srovnávací třídění algoritmus publikovaný v roce 1959 autorem L. R. Ford Jr. a Selmer M. Johnson.[1][2][3][4] Používá méně srovnání v nejhorší případ než nejlepší dříve známé algoritmy, binární vložení řazení a Sloučit třídění,[1] a po 20 let to byl třídicí algoritmus s nejmenším počtem známých srovnání.[5] Ačkoli to nemá praktický význam, zůstává v teoretickém zájmu v souvislosti s problémem třídění s minimálním počtem srovnání.[3] Stejný algoritmus mohl být také nezávisle objeven Stanisław Trybuła a Czen Ping.[4]
Algoritmus
Třídění sloučení a vložení provede na vstupu následující kroky z elementy:[6]
- Seskupte prvky do páry prvků libovolně, přičemž jeden prvek zůstane nepárový, pokud existuje lichý počet prvků.
- Provést srovnání, jedno na pár, k určení většího ze dvou prvků v každém páru.
- Rekurzivně seřadit větší prvky z každé dvojice, čímž se vytvoří seřazená sekvence z vstupních prvků ve vzestupném pořadí.
- Vložte na začátku prvek, který byl spárován s prvním a nejmenším prvkem .
- Vložte zbývající prvky do , jeden po druhém, se speciálně vybraným pořadí vkládání popsaným níže. Použití binární vyhledávání v posloupnosti (jak je popsáno níže) k určení polohy, ve které by měl být každý prvek vložen.
Algoritmus je navržen tak, aby využil výhody skutečnosti, že binární vyhledávání slouží k vložení prvků do jsou nejúčinnější (z hlediska analýzy nejhorších případů), když je délka prohledávané subsekvence o jednu menší než síla dvou. Je to proto, že pro tyto délky všechny výsledky hledání používají stejný počet srovnání jako každý jiný.[1] Chcete-li zvolit pořadí vkládání, které produkuje tyto délky, zvažte seřazené pořadí po kroku 4 výše uvedeného obrysu (před vložením zbývajících prvků) a nechte označit th prvek této seřazené sekvence. Tím pádem,
kde každý prvek s je spárován s prvkem který ještě nebyl vložen. (Neexistují žádné prvky nebo protože a byly spárovány navzájem.) Pokud je liché, zbývající nepárový prvek by měl být také očíslován jako s Větší než indexy spárovaných prvků. Poté lze poslední krok výše uvedeného obrysu rozšířit do následujících kroků:[1][2][3][4]
- Rozdělte vložené prvky do skupin se souvislými indexy. Existují dva prvky a v první skupině a součty velikostí každých dvou sousedních skupin tvoří posloupnost sil dvou. Velikost skupin tedy je: 2, 2, 6, 10, 22, 42, ...
- Seřadit vložené prvky podle jejich skupin (menší indexy do větších indexů), ale v rámci každé skupiny je uspořádat od větších indexů po menší indexy. Objednávka se tak stává
- Pomocí tohoto uspořádání vložte prvky do . Pro každý prvek , použijte binární vyhledávání od začátku až, ale ne včetně určit, kam vložit .
Analýza
Nechat označte počet srovnání, která v nejhorším případě při řazení způsobí sloučení a vložení Tento počet srovnání lze rozdělit jako součet tří výrazů:
- srovnání mezi dvojicemi položek,
- srovnání rekurzivního volání a
- určitý počet srovnání pro binární vložení použitá k vložení zbývajících prvků.
Ve třetím semestru je nejhorší počet srovnání pro prvky v první skupině dva, protože každý je vložen do subsekvence délky nejvýše tří. Za prvé, je vložen do tříprvkové subsekvence . Pak, je vložen do nějaké permutace tříprvkové subsekvence , nebo v některých případech do dvouprvkové subsekvence . Podobně prvky a druhé skupiny jsou vloženy do subsekvence délky nejvýše sedmi, pomocí tří srovnání. Obecněji řečeno, nejhorší počet srovnání prvků v tato skupina je , protože každý je vložen maximálně do subsekvence délky .[1][2][3][4] Sečtením počtu srovnání použitých pro všechny prvky a řešením výsledného relace opakování, tuto analýzu lze použít k výpočtu hodnot , dávat vzorec[7]
nebo v uzavřená forma,[8]
Pro čísla srovnání jsou[1]
Vztah k jiným druhům srovnání
Algoritmus se nazývá merge-insertion sort, protože počáteční srovnání, která provádí před jeho rekurzivním voláním (spárování libovolných položek a porovnání každé dvojice), jsou stejná jako počáteční srovnání Sloučit třídění, zatímco srovnání, která provádí po rekurzivním volání (pomocí binárního vyhledávání k vložení prvků jeden po druhém do seřazeného seznamu), se řídí stejným principem jako třídění vložení. V tomto smyslu jde o hybridní algoritmus který kombinuje jak sloučení, tak vložení.[9]
Pro malé vstupy (do ) jeho počet srovnání se rovná dolní mez o srovnávacím třídění . U větších vstupů je však počet srovnání provedených algoritmem sloučení a vložení větší než tato dolní mez. Třídění sloučení a vložení také provádí méně srovnání než třídění čísel, které počítají srovnání provedená v nejhorším případě binárním vložením sort nebo merge sort. Řazení čísel kolísá mezi a , se stejným vedoucím členem, ale horším konstantním faktorem v lineárním členu nižšího řádu.[1]
Merge-insertion sort je třídicí algoritmus s minimálním možným porovnáním pro položky kdykoli nebo a má nejméně známých známých srovnání .[10][11]Po 20 let byl druh sloučení a vkládání algoritmem třídění s nejmenším počtem známých srovnání pro všechny délky vstupů. V roce 1979 však Glenn Manacher publikoval další algoritmus třídění, který pro ještě větší vstupy používal ještě méně srovnání.[3][5]Přesně zůstává neznámo, kolik srovnání je pro třídění zapotřebí pro všechny , ale Manacherův algoritmus a pozdější algoritmy třídění, které rozbíjejí rekordy, využily všechny úpravy myšlenek pro sloučení a vložení.[3]
Reference
- ^ A b C d E F G Ford, Lester R. Jr.; Johnson, Selmer M. (1959), "Turnajový problém", Americký matematický měsíčník, 66: 387–389, doi:10.2307/2308750, PAN 0103159
- ^ A b C Williamson, Stanley Gill (2002), "2.31 Sloučit vložení (Ford – Johnson)", Kombinatorika pro informatiku„Doverské knihy o matematice, Courier Corporation, s. 66–68, ISBN 9780486420769
- ^ A b C d E F Mahmoud, Hosam M. (2011), „12.3.1 Ford-Johnsonův algoritmus“, Třídění: Teorie distribuce, Wiley Series v diskrétní matematice a optimalizaci, 54, John Wiley & Sons, str. 286–288, ISBN 9781118031131
- ^ A b C d Knuth, Donald E. (1998), "Sloučit vložení", Umění počítačového programování, Sv. 3: Třídění a vyhledávání (2. vyd.), S. 184–186
- ^ A b Manacher, Glenn K. (červenec 1979), „Ford-Johnsonův třídicí algoritmus není optimální“, Deník ACM, 26 (3): 441–456, doi:10.1145/322139.322145
- ^ Původní popis od Ford & Johnson (1959) seřazené prvky v sestupném pořadí. Zde uvedené kroky obrátí výstup podle popisu v Knuth (1998). Výsledný algoritmus provádí stejná srovnání, ale místo toho produkuje vzestupně.
- ^ Knuth (1998) připisuje souhrnný vzorec doktorátu z roku 1960 práce A. Hadiana. Aproximační vzorec byl již dán Ford & Johnson (1959).
- ^ Guy, Richard K.; Nowakowski, Richard J. (prosinec 1995), "Měsíční Nevyřešené problémy, 1969-1995 ", Americký matematický měsíčník, 102 (10): 921–926, doi:10.2307/2975272
- ^ Knuth (1998), str. 184: „Jelikož zahrnuje některé aspekty slučování a některé aspekty vkládání, říkáme tomu sloučit vložení."
- ^ Peczarski, Marcin (2004), „Nové výsledky v řazení podle minimálního srovnání“, Algorithmica, 40 (2): 133–145, doi:10.1007 / s00453-004-1100-7, PAN 2072769
- ^ Peczarski, Marcin (2007), „Algoritmus Ford-Johnson stále neporažený pro méně než 47 prvků“, Dopisy o zpracování informací, 101 (3): 126–128, doi:10.1016 / j.ipl.2006.09.001, PAN 2287331