Kartézský strom - Cartesian tree
v počítačová věda, a Kartézský strom je binární strom odvozeno ze sledu čísel; lze jej jednoznačně definovat z vlastností, o které se jedná halda -objednáno a to a symetrický (v pořadí) traverz stromu vrátí původní sekvenci. Představil Vuillemin (1980) v kontextu geometrických vyhledávání rozsahu datové struktury, Kartézské stromy byly také použity při definici šlapat a randomizovaný binární vyhledávací strom datové struktury pro binární vyhledávání problémy. Kartézský strom pro sekvenci může být sestaven v lineární čas používat zásobník algoritmus založený na hledání všechny nejbližší menší hodnoty v pořadí.
Definice
Kartézský strom pro posloupnost odlišných čísel lze jednoznačně definovat pomocí následujících vlastností:
- Kartézský strom pro sekvenci má jeden uzel pro každé číslo v sekvenci. Každý uzel je spojen s jedinou hodnotou sekvence.
- A symetrický (v pořadí) traverz stromu má za následek původní sekvenci. To znamená, že levý podstrom sestává z hodnot dřívějších než kořen v pořadí sekvence, zatímco pravý podstrom sestává z hodnot pozdějších než kořen a podobné omezení uspořádání platí v každém dolním uzlu stromu.
- Strom má halda vlastnost: nadřazený prvek libovolného jiného uživatele než root má nižší hodnotu než samotný uzel.[1]
Na základě vlastnosti haldy musí být kořen stromu nejmenší číslo v pořadí. Z toho lze také rekurzivně definovat samotný strom: kořen je minimální hodnota posloupnosti a levý a pravý podstrom jsou kartézské stromy pro subsekvence nalevo a napravo od kořenové hodnoty. Tři výše uvedené vlastnosti proto jednoznačně definují kartézský strom.
Pokud posloupnost čísel obsahuje opakování, může být kartézský strom definován stanovením konzistentního pravidla pro rozřazení (například určením, že první ze dvou stejných prvků je považován za menší ze dvou) před použitím výše uvedených pravidel.
Příklad karteziánského stromu je uveden na obrázku výše.
Hledání rozsahu a nejnižší společní předkové
Kartézské stromy mohou být použity jako součást efektivního datová struktura pro rozsah minimálních dotazů, a vyhledávání rozsahu problém s dotazy, které požadují minimální hodnotu v souvislé posloupnosti původní sekvence.[2] U kartézského stromu lze tuto minimální hodnotu najít na nejnižší společný předek hodnot zcela vlevo a vpravo v subsekvenci. Například v subsekvenci (12,10,20,15) sekvence zobrazené na prvním obrázku tvoří minimální hodnota subsekvence (10) nejnižšího společného předka hodnot vlevo a vpravo (12 a 15). Protože nejnižší společné předky lze nalézt v konstantním čase na dotaz, pomocí datové struktury, která ukládá lineární prostor a která může být konstruována v lineárním čase,[3] stejné omezení platí pro problém s minimalizací dosahu.
Bender & Farach-Colton (2000) obrátil tento vztah mezi dvěma problémy s datovou strukturou tím, že ukázal, že nejnižší společné předky ve vstupním stromu lze efektivně vyřešit použitím techniky, která není založená na stromu, pro minimalizaci rozsahu. Jejich datová struktura používá Prohlídka Euler technika transformace vstupního stromu do sekvence a poté ve výsledné sekvenci najde minima rozsahu. Sekvence vyplývající z této transformace má speciální formu (sousední čísla představující výšky sousedních uzlů ve stromu se liší o ± 1), které využívají ve své datové struktuře; k vyřešení problému s minimalizací rozsahu pro sekvence, které nemají tuto speciální formu, používají kartézské stromy k transformaci problému s minimalizací rozsahu na problém s nejnižším společným předkem a poté použijí techniku prohlídky Euler k opětovnému transformaci problému do jedné z minimalizace rozsahu pro sekvence s tímto speciálním formulářem.
Stejnému problému s minimalizací rozsahu lze také poskytnout alternativní interpretaci, pokud jde o prohledávání dvourozměrného rozsahu. Sbírka konečně mnoha bodů v Kartézské letadlo mohou být použity k vytvoření karteziánského stromu seřazením bodů podle jejich X-koordinátoři a pomocí y- souřadnice v tomto pořadí jako posloupnost hodnot, ze kterých je tento strom vytvořen. Li S je podmnožina vstupních bodů v rámci nějaké svislé desky definované nerovnostmi L ≤ X ≤ R, p je nejvíce vlevo S (ten s minimem X- koordinovaný) a q je pravý krajní bod v S (ten s maximem X-coordinate) pak nejnižší společný předek p a q ve karteziánském stromu je nejspodnější bod desky. Třístranný dotaz rozsahu, ve kterém je úkolem vypsat všechny body v oblasti ohraničené třemi nerovnostmi L ≤ X ≤ R a y ≤ T, lze zodpovědět nalezením tohoto nejspodnějšího bodu b, porovnání jeho y- koordinovat T, a (pokud bod leží v oblasti tří stran) pokračující rekurzivně ve dvou deskách ohraničených mezi nimi p a b a mezi b a q. Tímto způsobem, poté, co jsou identifikovány nejvíce vlevo a nejvíce vpravo body v desce, mohou být všechny body ve třístranné oblasti uvedeny v konstantním čase na bod.[4]
Stejná konstrukce nejnižších společných předků v karteziánském stromu umožňuje konstrukci datové struktury s lineárním prostorem, který umožňuje vzdálenosti mezi dvojicemi bodů v libovolném ultrametrický prostor být dotazován v konstantním čase na dotaz. Vzdálenost v ultrametriku je stejná jako vzdálenost cesta minimax hmotnost v minimální kostra metriky.[5] Z minimálního kostry lze sestrojit kartézský strom, jehož kořenový uzel představuje nejtěžší hranu minimálního kostry. Odstranění této hrany rozděluje minimální kostru na dva podstromy a karteziánské stromy rekurzivně konstruované pro tyto dva podstromy tvoří podřízené kořeny kartézského stromu. Listy kartézského stromu představují body metrického prostoru a nejnižší společný předchůdce dvou listů v kartézském stromu je nejtěžší hrana mezi těmito dvěma body v minimálním kostře, která má váhu rovnou vzdálenosti mezi dvěma body . Jakmile je nalezen minimální kostra a jsou roztříděny její okrajové váhy, může být kartézský strom sestaven v lineárním čase.[6]
Treaps
Protože kartézský strom je binární strom, je přirozené jej používat jako a binární vyhledávací strom pro uspořádanou posloupnost hodnot. Definování kartézského stromu na základě stejných hodnot, které tvoří vyhledávací klíče binárního vyhledávacího stromu, však nefunguje dobře: kartézský strom seřazené sekvence je jen cesta, zakořeněné v levém koncovém bodě a binární vyhledávání v tomto stromu degeneruje na sekvenční vyhledávání v cestě. Je však možné generovat vyváženější vyhledávací stromy generováním přednost hodnoty pro každý vyhledávací klíč, které se liší od samotného klíče, třídění vstupů podle jejich klíčových hodnot a použití odpovídající sekvence priorit ke generování kartézského stromu. Tuto konstrukci lze rovnocenně prohlížet ve výše popsaném geometrickém rámci, ve kterém X- souřadnice sady bodů jsou vyhledávací klávesy a y- souřadnice jsou priority.
Tuto myšlenku uplatnil Seidel a Aragon (1996), který jako prioritu navrhl použití náhodných čísel. Datová struktura vyplývající z této náhodné volby se nazývá a šlapat, kvůli jeho kombinaci binárního vyhledávacího stromu a funkcí binární haldy. Vložení do treap lze provést vložením nového klíče jako listu existujícího stromu, výběrem priority pro něj a následným provedením rotace stromu operace podél cesty z uzlu ke kořenu stromu k opravě jakéhokoli narušení vlastnosti haldy způsobené tímto vložením; smazání může být podobně provedeno konstantním množstvím změny stromu následovaným sekvencí rotací podél jedné cesty ve stromu.
Pokud jsou priority každého klíče vybrány náhodně a nezávisle jednou, kdykoli je klíč vložen do stromu, výsledný kartézský strom bude mít stejné vlastnosti jako náhodný binární vyhledávací strom, strom vypočítaný vložením klíčů do náhodně vybraného permutace počínaje prázdným stromem, přičemž každé vložení ponechá předchozí stromovou strukturu beze změny a nový uzel vloží jako list stromu. Náhodné binární vyhledávací stromy byly studovány mnohem déle a je známo, že se chovají dobře jako vyhledávací stromy (mají logaritmický hloubka s vysokou pravděpodobností); stejné dobré chování se přenáší na treaps. Je také možné, jak navrhují Aragon a Seidel, změnit prioritu často přístupných uzlů, což způsobí, že se budou pohybovat směrem ke kořeni treapu a urychlí budoucí přístupy ke stejným klíčům.
Efektivní konstrukce
Kartézský strom může být postaven v lineární čas Jednou z metod je jednoduše zpracovat hodnoty sekvence v pořadí zleva doprava a udržovat kartézský strom dosud zpracovaných uzlů ve struktuře, která umožňuje procházení stromu nahoru i dolů. Zpracovat každou novou hodnotu X, začněte v uzlu představujícím hodnotu před X v pořadí a následujte cestu od tohoto uzlu ke kořenu stromu, dokud nenajdete hodnotu y menší než X. Uzel X se stane správným dítětem ya předchozí pravé dítě z y se stane novým levým dítětem X. Celková doba pro tento postup je lineární, protože čas strávený hledáním rodiče y každého nového uzlu X může být účtováno proti počtu uzlů, které jsou odstraněny z cesty zcela vpravo ve stromu.[4]
Alternativní algoritmus konstrukce lineárního času je založen na všechny nejbližší menší hodnoty problém. Ve vstupní posloupnosti lze definovat levý soused hodnoty X být hodnotou, která nastane před X, je menší než X, a je blíže pozici X než jakákoli jiná menší hodnota. The pravý soused je definována symetricky. Sekvenci levých sousedů lze najít pomocí algoritmu, který udržuje a zásobník obsahující posloupnost vstupu. Pro každou novou hodnotu sekvence X, zásobník je vysunut, dokud není prázdný nebo jeho horní prvek je menší než X, a pak X je tlačen na hromádku. Levý soused X je v té době špičkovým prvkem X je tlačen. Správní sousedé lze najít použitím stejného algoritmu zásobníku na zadní stranu sekvence. Rodič X na kartézském stromu je buď levý soused X nebo správný soused X, podle toho, co existuje a má větší hodnotu. Levého a pravého souseda lze také efektivně postavit pomocí paralelní algoritmy, takže tato formulace může být použita k vývoji efektivních paralelních algoritmů pro konstrukci kartézského stromu.[7]
Další algoritmus lineárního času pro konstrukci kartézského stromu je založen na rozdělení a dobývání. Algoritmus konkrétně rekurzivně konstruuje strom na každé polovině vstupu a poté oba stromy spojuje tak, že vezme pravou páteř levého stromu a levou páteř pravého stromu (obě jsou cesty, jejichž kořen k listu pořadí seřadí jejich hodnoty od nejmenších po největší) a provede standard slučování operace, nahrazení těchto dvou cest ve dvou stromech jedinou cestou, která obsahuje stejné uzly. Ve sloučené cestě je nástupce v seřazeném pořadí každého uzlu z levého stromu umístěn do jeho pravého podřízeného prvku a nástupce každého uzlu z pravého stromu je umístěn do jeho levého podřízeného prvku, na stejnou pozici, která byla dříve použita pro jeho nástupce v páteři. Levé podřízené uzly z levého stromu a pravé podřízené uzly z pravého stromu zůstanou beze změny. Algoritmus je také paralelizovatelný, protože na každé úrovni rekurze lze každý ze dvou dílčích problémů vypočítat paralelně a sloučení lze provést efektivně paralelizovat také.[8]
Aplikace při třídění
Levcopoulos & Petersson (1989) popsat a třídicí algoritmus na základě kartézských stromů. Popisují algoritmus založený na stromu s maximem v kořenovém adresáři, ale lze jej přímo upravit tak, aby podporoval kartézský strom s konvencí, že minimální hodnota je v kořenovém adresáři. Kvůli konzistenci je tato upravená verze algoritmu popsána níže.
Algoritmus Levcopoulos – Petersson lze chápat jako verzi výběr řazení nebo hromada třídění který udržuje a prioritní fronta kandidátských minim a že v každém kroku najde a odstraní minimální hodnotu v této frontě a přesune tuto hodnotu na konec výstupní sekvence. Ve svém algoritmu se prioritní fronta skládá pouze z prvků, jejichž rodič ve karteziánském stromu již byl nalezen a odstraněn. Algoritmus tedy sestává z následujících kroků:
- Vytvořte kartézský strom pro vstupní sekvenci
- Inicializujte prioritní frontu, která zpočátku obsahuje pouze kořen stromu
- Zatímco prioritní fronta není prázdná:
- Najděte a odeberte minimální hodnotu X ve frontě priorit
- Přidat X do výstupní sekvence
- Přidejte děti s kartézským stromem X do prioritní fronty
Jak ukazují Levcopoulos a Petersson, u vstupních sekvencí, které jsou již téměř seřazené, zůstane velikost prioritní fronty malá, což této metodě umožní využít téměř seřazený vstup a spustit rychleji. Nejhorší doba běhu tohoto algoritmu je O (n logk), kde k je průměr nad všemi hodnotami X v pořadí počet po sobě jdoucích párů hodnot sekvence, které jsou v závorkách X. Dokazují také dolní mez, že pro každého n a k = ω (1), jakýkoli srovnávací algoritmus řazení musí používat Ω (n logk) srovnání pro některé vstupy.
Dějiny
Kartézské stromy byly zavedeny a pojmenovány Vuillemin (1980). Název je odvozen od Kartézská souřadnice systém pro rovinu: ve Vuilleminově verzi této struktury, stejně jako ve výše popsané aplikaci pro vyhledávání dvourozměrného rozsahu, má kartézský strom pro množinu bodů seřazené pořadí bodů podle jejich X-coordinates as its symetric traversal order, and it has the heap property according to the y- souřadnice bodů.Gabow, Bentley & Tarjan (1984) a následující autoři se řídili definicí, ve které je kartézský strom definován ze sekvence; tato změna zobecňuje geometrické nastavení Vuilleminu, aby umožňoval jiné sekvence než seřazené pořadí X-coordinates a umožňuje použití karteziánského stromu i na negeometrické problémy.
Poznámky
- ^ V některých odkazech je pořadí obrácené, takže nadřazený prvek libovolného uzlu má vždy větší hodnotu a kořenový uzel obsahuje maximální hodnotu.
- ^ Gabow, Bentley & Tarjan (1984); Bender & Farach-Colton (2000).
- ^ Harel & Tarjan (1984); Schieber & Vishkin (1988).
- ^ A b Gabow, Bentley & Tarjan (1984).
- ^ Hu (1961); Leclerc (1981)
- ^ Demaine, Landau & Weimann (2009).
- ^ Berkman, Schieber & Vishkin (1993).
- ^ Shun & Blelloch (2014).
Reference
- Bender, Michael A .; Farach-Colton, Martin (2000), „Problém LCA se vrátil“, Sborník ze 4. latinskoamerického symposia o teoretické informatice, Springer-Verlag, Přednášky z informatiky 1776, s. 88–94.
- Berkman, Omer; Schieber, Baruch; Vishkin, Uzi (1993), „Optimální dvojnásobně logaritmické paralelní algoritmy založené na nalezení všech nejbližších menších hodnot“, Journal of Algorithms, 14 (3): 344–370, doi:10.1006 / jagm.1993.1018.
- Demaine, Erik D.; Landau, Gad M .; Weimann, Oren (2009), „O kartézských stromech a minimálním rozsahu dotazů“, Automaty, jazyky a programování, 36. mezinárodní kolokvium, ICALP 2009, Rhodos, Řecko, 5. – 12. Července 2009, Přednášky v informatice, 5555, str. 341–353, doi:10.1007/978-3-642-02927-1_29, hdl:1721.1/61963, ISBN 978-3-642-02926-4.
- Fischer, Johannes; Heun, Volker (2006), „Teoretická a praktická vylepšení problému RMQ s aplikacemi pro LCA a LCE“, Sborník 17. výročního sympozia o kombinatorickém porovnávání vzorů, Přednášky v informatice, 4009, Springer-Verlag, str. 36–48, doi:10.1007/11780441_5, ISBN 978-3-540-35455-0
- Fischer, Johannes; Heun, Volker (2007), „New Succinct Reprezentation of RMQ-Information and Improvements in the Enhanced Suffix Array.“, Proceedings of the International Symposium on Combinatorics, Algorithms, Probabilistic and Experimental Methododies, Přednášky v informatice, 4614, Springer-Verlag, str. 459–470, doi:10.1007/978-3-540-74450-4_41, ISBN 978-3-540-74449-8
- Gabow, Harold N .; Bentley, Jon Louis; Tarjan, Robert E. (1984), "Škálování a související techniky pro geometrické problémy", STOC '84: Proc. 16. ACM Symp. Teorie výpočtu, New York, NY, USA: ACM, s. 135–143, doi:10.1145/800057.808675, ISBN 0-89791-133-4.
- Harel, Dov; Tarjan, Robert E. (1984), „Rychlé algoritmy pro hledání nejbližších společných předků“, SIAM Journal on Computing, 13 (2): 338–355, doi:10.1137/0213024.
- Hu, T. C. (1961), „Problém s maximální kapacitou trasy“, Operační výzkum, 9 (6): 898–900, doi:10,1287 / před 9.6.898, JSTOR 167055.
- Leclerc, Bruno (1981), „Description combineatoire des ultramétriques“, Centre de Mathématique Sociale. École Pratique des Hautes Études. Mathématiques et Sciences Humaines (ve francouzštině) (73): 5–37, 127, PAN 0623034.
- Levcopoulos, Christos; Petersson, Ola (1989), „Heapsort - přizpůsobený pro předtříděné soubory“, WADS '89: Proceedings of the Workshop on Algorithms and Data Structures, Přednášky v informatice, 382, Londýn, Velká Británie: Springer-Verlag, str. 499–509, doi:10.1007/3-540-51542-9_41.
- Seidel, Raimund; Aragon, Cecilia R. (1996), "Randomizované vyhledávací stromy", Algorithmica, 16 (4/5): 464–497, doi:10,1007 / s004539900061.
- Schieber, Baruch; Vishkin, Uzi (1988), „O hledání nejnižších společných předků: zjednodušení a paralelizace“, SIAM Journal on Computing, 17 (6): 1253–1262, doi:10.1137/0217079.
- Shun, Julian; Blelloch, Guy E. (2014), „Simple Parallel Cartesian Tree Algorithm and its Application to Parallel Suffix Tree Construction“, Transakce ACM na paralelním výpočtu, 1: 1–20, doi:10.1145/2661653.
- Vuillemin, Jean (1980), „Sjednocující pohled na datové struktury“, Komunikace ACM, New York, NY, USA: ACM, 23 (4): 229–239, doi:10.1145/358841.358852.