Stacková klasifikace - Stack-sortable permutation
v matematika a počítačová věda, a stohovatelná permutace (také nazývaný a stromová permutace)[1] je permutace jejichž prvky mohou být tříděny algoritmem, jehož vnitřní úložiště je omezeno na jeden struktura dat zásobníku. Permutace se zařazením do zásobníku jsou přesně ty permutace, které neobsahují permutační vzor 231; počítá je Katalánská čísla, a mohou být umístěny do bijekce s mnoha dalšími kombinatorickými objekty se stejnou funkcí počítání včetně Dyckovy cesty a binární stromy.
Třídění s hromadou
Nejprve nastolil problém řazení vstupní sekvence pomocí zásobníku Knuth (1968), který uvedl následující lineární čas algoritmus (úzce souvisí s algoritmy pro pozdější všechny nejbližší menší hodnoty problém):
- Inicializujte prázdný zásobník
- Pro každou vstupní hodnotu X:
- Zatímco zásobník je neprázdný a X je větší než horní položka v zásobníku, vysuňte zásobník na výstup
- Tlačit X na hromádku
- Zatímco zásobník není prázdný, vysuňte jej na výstup
Knuth si všiml, že tento algoritmus správně třídí některé vstupní sekvence a jiné nezdaří. Například posloupnost 3,2,1 je správně tříděna: všechny tři prvky jsou vloženy do zásobníku a poté vyskočeny v pořadí 1,2,3. Sekvence 2,3,1 však není správně tříděna: algoritmus nejprve stiskne 2 a zobrazí ji, když uvidí větší vstupní hodnotu 3, což způsobí, že 2 bude vydán před 1 a ne po něm.
Protože tento algoritmus je a porovnání řazení, jeho úspěch nebo neúspěch nezávisí na číselných hodnotách vstupní sekvence, ale pouze na jejich relativním pořadí; tj. vstup může být popsán pomocí permutace potřebné k vytvoření tohoto vstupu ze seřazené sekvence stejné délky. Knuth charakterizoval permutace, které tento algoritmus správně seřadí, jako přesně ty permutace, které neobsahují permutační vzor 231: tři prvky X, y, a z, zobrazující se ve vstupu v příslušném pořadí, s z < X < y. Navíc si všiml, že pokud algoritmus nedokáže řadit vstup, pak tento vstup nelze třídit pomocí jediného zásobníku.
Stejně jako inspirace pro mnoho následných prací na třídění pomocí složitějších systémů zásobníků a souvisejících datových struktur,[2] Knuthův výzkum zahájil studium permutační vzory a permutačních tříd definovaných zakázanými vzory.
Bijekce a výčet
Posloupnost stisknutí a vyskakování provedená Knuthovým třídicím algoritmem, jak třídí formu permutace s možností řazení do zásobníku Dyck jazyk: reinterpretace push jako levé závorky a popu jako pravé závorky produkuje řetězec vyvážených závorek. Každý řetězec Dyck navíc tímto způsobem pochází z permutace s možností třídění podle zásobníku a každé dvě různé permutace s možností třídění podle zásobníku produkují různé řetězce Dyck. Z tohoto důvodu počet permutací délky, které lze řadit do zásobníku n je stejný jako počet řetězců Dyck o délce 2n, Katalánské číslo
Obměny s možností stohování mohou být také přeloženy přímo do az (bez označení) binární stromy, další kombinatorická třída jehož funkce počítání je posloupnost katalánských čísel. Binární strom může být transformován na permutaci se zařazením do zásobníku číslováním jeho uzlů pořadí zleva doprava a poté uvedením těchto čísel v pořadí, v jakém by je navštívila a předobjednat průchod stromu: nejprve kořen, potom levý podstrom, poté pravý podstrom, pokračování rekurzivně v rámci každého podstromu. V opačném směru může být dekódována do zásobníku permutace do stromu, ve kterém je první hodnota X permutace odpovídá kořenu stromu, další X - 1 hodnoty jsou dekódovány rekurzivně, aby byly dítěti podřízené kořeny, a zbývající hodnoty jsou opět dekódovány rekurzivně, aby byly dány správné podřízené.[1]
Několik dalších tříd permutací může být také umístěno do bijekce s permutacemi se zařazením do zásobníku. Například permutace, které se vyhýbají vzorům 132, 213 a 312, mohou být vytvořeny jednotlivě z permutací se zařazením do zásobníku (vyhýbání se 231) obrácením permutace a nahrazením každé hodnoty X v obměně n + 1 − Xnebo obě operace dohromady. 312 vyhýbající se permutace jsou také inverzemi 231 vyhýbajících se permutací a byly nazývány stohovatelné permutace protože se jedná o permutace, které lze vytvořit z permutace identity posloupností operací push-from-input a pop-to-output na zásobníku.[4]Tak jako Knuth (1968) je třeba poznamenat, že permutace vyhýbající se 123 a 321 mají také stejnou funkci počítání, přestože jsou méně přímo spojené s permutacemi vhodnými pro zásobník.
Náhodné permutace se zařazením do zásobníku
Rotem (1981) zkoumá vlastnosti zvolených permutací se zařazením do zásobníku rovnoměrně náhodně mezi všemi takovými permutacemi dané délky očekávaná délka z nejdelší sestupná posloupnost v takové obměně je , lišící se konstantním faktorem od neomezených náhodných permutací (pro které je očekávaná délka přibližně ). Očekávaná délka nejdelší vzestupné sekvence se ještě silněji liší od neomezených permutací: je . Očekávaný počet hodnot v rámci permutace, které jsou větší než všechny předchozí hodnoty, je pouze , menší než jeho logaritmická hodnota pro neomezené permutace. A očekávaný počet inverze je , na rozdíl od jeho hodnoty pro neomezené obměny.
Další vlastnosti
Každá permutace definuje a permutační graf, graf, jehož vrcholy jsou prvky permutace a jejichž hrany spojují dvojice prvků, které jsou obráceně permutací. Permutační grafy permutací se zařazením do zásobníku jsou triviálně perfektní.[4]
Pro každý prvek i permutace p, definovat bi být počet dalších prvků, které jsou nalevo od a větší než i. Pak p je stohovatelný tehdy a jen tehdy, pro všechny i, bi − bi + 1 ≤ 1.[1]
Algoritmy
Knott (1977) používá bijekci mezi permutacemi vhodnými pro zásobník a binárními stromy k definování číselné pozice pro každý binární strom a ke konstrukci účinných algoritmů pro výpočet hodnosti stromu („hodnocení“) a pro výpočet stromu s danou hodností („bez hodnocení“ ").
Micheli & Rossin (2006) definovány dvě operace úprav permutací: vymazání (provedení a permutační vzor ) a jeho inverzní. Pomocí stejné korespondence mezi stromy a permutacemi zjistili, že tyto operace odpovídají kontrakce hran ve stromu a jeho inverzi. Použitím a polynomiální čas dynamické programování algoritmus pro upravit vzdálenost na stromech ukázali, že vzdálenost úprav mezi dvěma permutacemi, které lze řadit do zásobníku (a tedy také nejdelší běžný vzor), lze najít v polynomiálním čase. Tato technika byla později zobecněna na algoritmy pro hledání nejdelších běžných vzorců oddělitelné obměny;[5] nejdelší běžný problém se vzorem je však NP-Complete pro libovolné obměny.[6]
Poznámky
- ^ A b C Knott (1977).
- ^ Tarjan (1972); Avis & Newborn (1981); Rosenstiehl & Tarjan (1984); Bóna (2002); Felsner & Pergel (2008). Viz také mnoho dalších odkazů od Bóny.
- ^ Knuth (1968); Rotem (1981).
- ^ A b Rotem (1981).
- ^ Bouvel, Rossin & Vialette (2007).
- ^ Micheli & Rossin (2006).
Reference
- Avis, David; Novorozenec, Monroe (1981), "On pop-stacks in series", Utilitas Mathematica, 19: 129–140, PAN 0624050.
- Bóna, Miklósi (2002), „Průzkum oborů třídění zásobníků“, Electronic Journal of Combinatorics, 9 (2): A1, PAN 2028290.
- Bouvel, Mathilde; Rossin, Dominique; Vialette, Stéphane (2007), „Nejdelší běžný oddělitelný vzor mezi permutacemi“, Kombinatorické porovnávání vzorů (CPM 2007), Přednášky v informatice, 4580, Springer, str. 316–327, doi:10.1007/978-3-540-73437-6_32.
- Felsner, Stefan; Pergel, Martin (2008), „Složitost třídění se sítěmi zásobníků a front“, Proc. 16. Eur. Symp. Algoritmy, Karlsruhe, Německo, str. 417–429, doi:10.1007/978-3-540-87744-8_35, ISBN 978-3-540-87743-1.
- Knott, Gary D. (únor 1977), „Systém číslování binárních stromů“, Komunikace ACM, 20 (2): 113–115, doi:10.1145/359423.359434.
- Knuth, Donald (1968), „Vol. 1: Fundamental Algorithms“, Umění počítačového programování „Reading, Mass .: Addison-Wesley.
- Micheli, Anne; Rossin, Dominique (2006), „Upravit vzdálenost mezi neoznačenými objednanými stromy“, Teoretická informatika a aplikace, 40 (4): 593–609, arXiv:matematika / 0506538, doi:10.1051 / ita: 2006043, PAN 2277052.
- Rosenstiehl, Pierre; Tarjan, Robert E. (1984), „Gaussovy kódy, rovinné hamiltonovské grafy a permutace s možností řazení do zásobníku“, Journal of Algorithms, 5 (3): 375–390, doi:10.1016 / 0196-6774 (84) 90018-X, PAN 0756164
- Rotem, D. (1981), "Stack rare permutations", Diskrétní matematika, 33 (2): 185–196, doi:10.1016 / 0012-365X (81) 90165-5, PAN 0599081.
- Tarjan, Robert (Duben 1972), "Řazení pomocí sítí front a zásobníků", Deník ACM, 19 (2): 341–346, doi:10.1145/321694.321704.