Nejlepší strom - Top tree
A horní strom je datová struktura na základě binárního stromu pro nekořenovanou dynamiku stromy který se používá hlavně pro různé operace související s cestami. Umožňuje to jednoduché algoritmy rozděl a panuj. Od té doby byl rozšířen tak, aby udržoval dynamicky různé vlastnosti a strom jako je průměr, střed a medián.
Špičkový strom je definován pro podkladový strom a sada maximálně dvou vrcholů nazývaných jako Vnější hraniční vrcholy
Glosář
Hraniční uzel
Vidět Hraniční vrchol
Hraniční vrchol
Vrchol v připojeném podstromu je a Hraniční vrchol pokud je spojen s vrcholem mimo podstrom hranou.
Vnější hraniční vrcholy
Až pár vrcholů v horním stromu lze nazvat jako externí hraniční vrcholy, lze je považovat za hraniční vrcholy klastru, který představuje celý horní strom.
Klastr
A shluk je propojený podstrom s maximálně dvěma Hraniční vrcholy Sada Hraniční vrcholy daného klastru je označen jako S každým klastrem uživatel může přidružit některé meta informace a dát způsoby, jak to udržovat pod různými interní operace.
Path Cluster
Li obsahuje alespoň jeden okraj se nazývá a Path Cluster.
Klastr bodů
Vidět Shluk listů
Shluk listů
Li neobsahuje žádnou hranu, tj. má jen jednu Hraniční vrchol pak se nazývá a Shluk listů.
Edge Cluster
Cluster obsahující jednu hranu se nazývá Edge Cluster.
Shluk okraje listu
List v původním klastru je reprezentován klastrem s jediným hraničním vrcholem a nazývá se a Shluk okraje listu.
Cluster Edge Path
Jsou volány Edge Clustery se dvěma hraničními uzly Cluster Edge Path.
Interní uzel
Uzel v \ se nazývá Interní uzel z
Cesta klastru
Cesta mezi Hraniční vrcholy z se nazývá cesta klastru z a je označen
Sloučitelné klastry
Dva klastry a jsou Sloučitelné -li je singletonová sada (mají společný právě jeden uzel) a je shluk.
Úvod
Nejlepší stromy se používají k udržování dynamického lesa (sady stromů) pod operace propojení a řezání.
Základní myšlenkou je udržovat rovnováhu Binární strom logaritmické výšky v počtu uzlů v původním stromu (tj. v čas) ; the horní strom v podstatě představuje rekurzivní dělení původního stromu do shluky.
Obecně strom může mít na okrajích váhu.
S okraji původního stromu je korespondence jedna k jedné a listové uzly horního stromu a každý vnitřní uzel představuje klastr, který je vytvořen díky spojení klastrů, které jsou jeho podřízenými.
Horní stromovou datovou strukturu lze inicializovat v čas.
Proto horní strom přes ( ) je binární strom takový, že
- Uzly jsou shluky ( );
- Listy jsou hrany
- Sourozenecké klastry jsou sousedé v tom smyslu, že se protínají v jediném vrcholu, a pak je jejich mateřský klastr jejich spojením.
- Kořen je strom sám se sadou maximálně dvou externích hraničních vrcholů.
Strom s jediným vrcholem má prázdný horní strom a jeden s pouze hranou je jen jeden uzel.
Tyto stromy jsou volně rozšiřitelný umožňující uživateli širokou škálu flexibility a produktivity, aniž by se zabýval podrobnostmi vnitřního fungování datové struktury, což se také označuje jako Černá skříňka.
Dynamické operace
Následující tři jsou uživatelem povolené aktualizace doménové struktury.
- Odkaz (v, w): Kde a jsou vrcholy v různých stromech 1 a 2. Vrátí jeden horní strom představující protiw
- Řez (v, w): Odstraní okraj ze stromu s horním stromem čímž se z něj staly dva stromy proti a w a vrácení dvou nejlepších stromů proti a w.
- Vystavit (S): Je volán jako podprogram pro implementaci většiny dotazů do horního stromu. obsahuje maximálně 2 vrcholy. Vytváří původní externí vrcholy jako normální vrcholy a vytváří z nich vrcholy nové externí hraniční vrcholy horního stromu. Li je neprázdné vrací nový kořenový cluster s Vystavit ({v, w}) selže, pokud jsou vrcholy z různých stromů.
Interní operace
The Aktualizace lesa všechny jsou prováděny v pořadí nejvýše Interní operace, jejichž sekvence se počítá dále čas. Může se stát, že během aktualizace stromu se listový klastr může změnit na shluk cest a naopak. Aktualizace horního stromu se provádí výhradně těmito interními operacemi.
The se aktualizuje voláním uživatelem definované funkce spojené s každou vnitřní operací.
- Spojit Tady a jsou Sloučitelné klastry, vrátí se jako nadřazený klastr a a s hraničními vrcholy jako hraničními vrcholy Počítá použitím a
- Rozdělit Tady je kořenový cluster Aktualizuje se a použitím a pak odstraní cluster z .
Split je obvykle implementován pomocí Čistý metoda, která volá uživatelskou metodu pro aktualizace a použitím a aktualizace takže je známo, že u jeho dětí není potřeba žádná čekající aktualizace. Než je zahozeno bez volání uživatelem definovaných funkcí. Čistý je často vyžadován pro dotazy bez nutnosti Rozdělit.Pokud Split nepoužije Clean podprogram a je vyžadováno Clean, jeho efektu lze dosáhnout s režií kombinací Spojit a Rozdělit.
Další dvě funkce jsou analogické s výše uvedenými dvěma a používají se pro základní klastry.
- Vytvořit Vytvoří klastr pro okraj Sady je počítán od nuly.
- Vymýtit je hraniční shluk Uživatelem definovaná funkce je volána ke zpracování a pak shluk je odstraněn z horního stromu.
Non místní vyhledávání
Uživatel může definovat Vybrat operace, která pro kořenový (nonleaf) klastr vybere jeden ze svých podřízených klastrů. Horní stromová černá schránka poskytuje Vyhledávání rutina, která organizuje Vybrat dotazy a reorganizace horního stromu (pomocí interních operací) tak, aby lokalizoval jedinou hranu v průsečíku všech vybraných klastrů. Někdy by hledání mělo být omezeno na cestu. Pro tyto účely existuje varianta nelokálního vyhledávání, pokud jsou v kořenovém clusteru dva vnější hraniční vrcholy , hrana se prohledává pouze na cestě . Stačí provést následující úpravy: Pokud je pouze jeden z podřízených kořenových clusterů cesta clusteru, je vybrán ve výchozím nastavení bez volání Vybrat úkon.
Příklady nelokálního vyhledávání
Nalezení i-té hrany na delší cestě z na by mohlo být provedeno = Vystavit ({v, w}) následován Vyhledávání() s příslušnými Vybrat. Implementovat Vybrat používáme globální proměnnou představující a globální proměnná představující Zvolte vybere klastr s iff délka je alespoň . Pro podporu operace musí být délka udržována v .
Podobný úkol lze formulovat pro graf s hranami s délkami jiných jednotek. V takovém případě by vzdálenost mohla oslovit hranu nebo vrchol mezi dvěma hranami. Mohli bychom definovat Choose tak, aby se v druhém případě vrátila hrana vedoucí k vrcholu. Mohla by být definována aktualizace zvyšující všechny délky hran podél cesty konstantou. V takovém scénáři se tyto aktualizace provádějí v konstantním čase právě v kořenovém clusteru. Čistý je nutné distribuovat zpožděnou aktualizaci dětem. The Čistý by měl být volán před Vyhledávání je vyvolána. Chcete-li zachovat délku v by v takovém případě vyžadovalo udržovat jednotku délky v také.
Nalezení středu stromu obsahujícího vrchol lze provést vyhledáním hrany bicentru nebo hrany se středem jako jedním koncovým bodem. Okraj lze najít = Vystavit ({v}) následován Vyhledávání() s příslušnými Vybrat. Výběr vybírá mezi dětmi s dítě s vyšší maximální vzdáleností. Aby se podpořila operace, měla by se v mezilehlém vrcholu udržovat maximální vzdálenost v podstromu klastru . To vyžaduje také údržbu délky cesty klastru.
Zajímavé výsledky a aplikace
Řadu zajímavých aplikací původně implementovaných jinými metodami lze snadno implementovat pomocí rozhraní horního stromu. Některé z nich zahrnují
- ([SLEATOR AND TARJAN 1983]). Můžeme udržovat dynamickou sbírku vážených stromů čas na odkaz a výřez, podpora dotazů na maximální hmotnost hrany mezi dvěma vrcholy v čas.
- Osnova dokladu: Zahrnuje udržování maximální hmotnosti (max_wt) na jeho cestě klastru v každém uzlu, pokud se jedná o klastr bodů, pak max_wt () je inicializován jako Když je klastr sjednocení dvou klastrů, pak je to maximální hodnota dvou sloučených klastrů. Pokud musíme najít maximální hmotnost mezi a pak ano Odhalit a nahlásit max_wt
- ([SLEATOR AND TARJAN 1983]). Ve scénáři výše uvedené aplikace můžeme také přidat společnou váhu ke všem hranám na dané cestě · · · v čas.
- Osnova důkazu: Zavádíme váhu zvanou extra (), které se přidá ke všem hranám v Který je náležitě udržován; rozdělit() to vyžaduje pro každou cestu dítě z nastavíme max_wt (A): = max_wt () + navíc () a navíc (): = extra () + navíc (). Pro : = připojit ( ), nastavíme max_wt (): = max {max_wt (), max_wt ()} a navíc (): = 0. Nakonec najdete maximální váhu na trase · · · jsme si stanovili : = Vystavit a vrátit max_wt ().
- ([GOLDBERG ET AL. 1991]). Můžeme požádat o maximální váhu v podkladovém stromu obsahujícím daný vrchol v čas.
- Osnova důkazu: To vyžaduje udržování dalších informací o maximální hmotnosti okraje cesty bez clusteru v clusteru v rámci operací Sloučit a Rozdělit.
- Vzdálenost mezi dvěma vrcholy a najdete v čas jako délka (vystavit).
- Osnova dokladu: Zachováme délku délky () cesty klastru. Délka je udržována jako maximální hmotnost, kromě toho, pokud je vytvořen spojením (Sloučit), délkou () je součet délek uložených s jeho potomky cesty.
- Dotazy týkající se průměru stromu a jeho následné údržby trvá čas.
- Centrum a medián lze udržovat pod operacemi Link (Sloučit) a Vyjmout (Rozdělit) a dotazovat se nelokálním vyhledáváním v čas.
- Graf by mohl být udržován, což umožňuje aktualizovat sadu edge a klást dotazy na připojení edge 2. Amortizovaná složitost aktualizací je . Dotazy by mohly být implementovány ještě rychleji. Algoritmus není triviální, používá prostor ([HOLM, LICHTENBERG, THORUP 2000]).
- Graf by mohl být udržován, což umožňuje aktualizovat sadu hran a ptát se na dotazy na vrchol 2-připojení. Amortizovaná složitost aktualizací je . Dotazy by mohly být implementovány ještě rychleji. Algoritmus není triviální, používá vesmír ([HOLM, LICHTENBERG, THORUP 2001]).
- Nejlepší stromy lze použít ke kompresi stromů způsobem, který nikdy není mnohem horší než DAG komprese, ale může být exponenciálně lepší.[1]
Implementace
Nejlepší stromy byly implementovány různými způsoby, některé z nich zahrnují implementaci pomocí a Víceúrovňový oddíl (Špičkové stromy a algoritmy dynamických grafů Jacob Holm a Kristian de Lichtenberg. Technická zpráva), a dokonce i pomocí Sleator-Tarjan s-t stromy (obvykle s amortizovanými časovými hranicemi), Fredericksonovy topologické stromy (s nejhorším časovým ohraničením) (Alstrup et al. Údržba informací v plně dynamických stromech se špičkovými stromy).
Amortizované implementace jsou jednodušší as malými multiplikativními faktory v časové složitosti. Naopak nejhorší implementace umožňují zrychlení dotazů vypnutím nepotřebných aktualizací informací během dotazu (implementováno vytrvalost techniky). Po zodpovězení dotazu se použije původní stav horního stromu a verze dotazu se zahodí.
Použití víceúrovňového rozdělení na oddíly
Jakékoli rozdělení klastrů stromu může být reprezentován stromem CPT clusterového oddílu nahrazením každého klastru ve stromu hranou. Použijeme-li strategii P pro rozdělení pak by CPT byl CPTP To se provádí rekurzivně, dokud nezůstane pouze jedna hrana.
Všimli bychom si, že všechny uzly odpovídajícího horního stromu jsou jedinečně mapovány do okrajů tohoto víceúrovňového oddílu. Ve víceúrovňovém oddílu mohou být některé hrany, které neodpovídají žádnému uzlu v horním stromu, jedná se o hrany, které představují pouze jedno dítě v úrovni pod ním, tj. Jednoduchý klastr. Pouze hrany, které odpovídají složeným klastrům, odpovídají uzlům v horním stromu
Při dělení stromu je důležitá strategie dělení do shluků. Pouze pečlivá strategie zajistí, že skončíme v výška Víceúrovňový oddíl (a tedy horní strom).
- Počet hran v následujících úrovních by se měl snížit o konstantní faktor.
- Pokud se při aktualizaci změní nižší úroveň, měli bychom být schopni aktualizovat úroveň bezprostředně nad ní pomocí maximálně konstantního počtu vložení a odstranění.
Výše uvedená strategie rozdělení zajišťuje údržbu horního stromu čas.
Reference
- Stephen Alstrup, Jacob Holm, Kristian De Lichtenberg a Mikkel Thorup, Udržování informací v plně dynamických stromech se špičkovými stromy, ACM Transaction on Algorithms (TALG), sv. 1 (2005), 243–264, doi:10.1145/1103963.1103966
- Stephen Alstrup, Jacob Holm, Kristian De Lichtenberg a Mikkel Thorup, Poly-logaritmické deterministické plně dynamické algoritmy pro připojení, minimální kostru, 2 hrany a biconnectivity, Journal of the ACM, Vol. 48 Vydání 4 (červenec 2001), 723–760, doi:10.1145/502090.502095
- Donald Knuth. Umění počítačového programování: Základní algoritmy, Třetí edice. Addison-Wesley, 1997. ISBN 0-201-89683-4 . Oddíl 2.3: Stromy, s. 308–423.
- Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest, a Clifford Stein. Úvod do algoritmů, Druhé vydání. MIT Press a McGraw-Hill, 2001. ISBN 0-262-03293-7 . Oddíl 10.4: Zastoupení kořenových stromů, s. 214–217. Kapitoly 12–14 (Binární vyhledávací stromy, červeno-černé stromy, rozšiřující datové struktury), s. 253–320.
- ^ Komprese stromů s nejlepšími stromy. BILLE, GOERTZ, LANDAU, WEIMANN 2013 arXiv: 1304,5702 [cs.DS]