Hanojská věž - Tower of Hanoi - Wikipedia

Sada modelů Hanojské věže (s 8 disky)
Animované řešení Hanojská věž puzzle pro T(4, 3)
Interaktivní displej Hanojské věže na Muzeum Universum v Mexico City

The Hanojská věž (nazývané také Brahmova věž nebo Lucasova věž[1] a někdy pluralizované jako Věže) je matematická hra nebo hádanka. Skládá se ze tří prutů a řady disků různých velikostí, které lze nasunout na jakoukoli tyč. Hádanka začíná disky v úhledném stohu ve vzestupném pořadí podle velikosti na jedné tyči, nejmenší nahoře, čímž vytváří kuželovitý tvar.

Cílem této hádanky je přesunout celý stack na jiný prut, a to při dodržení následujících jednoduchých pravidel:

  1. Najednou lze přesunout pouze jeden disk.
  2. Každý tah spočívá v odebrání horního disku z jednoho ze stohů a jeho umístění na jiný stoh nebo na prázdnou tyč.
  3. Na větší disk nesmí být umístěn žádný větší disk.

Se 3 disky lze puzzle vyřešit v 7 tazích. Minimální počet tahů potřebných k vyřešení hádanky Tower of Hanoi jsou 2n - 1, kde n je počet disků.

Počátky

Hádanka byla vynalezena francouzština matematik Édouard Lucas v roce 1883. Téměř okamžitě se objevily četné mýty týkající se starodávné a mystické povahy skládačky.[2] Existuje příběh o indický chrám v Kashi Vishwanath který obsahuje velkou místnost se třemi časem opotřebovanými sloupky, obklopenou 64 zlatými disky. Bráhman kněží, jednající podle příkazu starodávného proroctví, od té doby pohybovali těmito disky v souladu s neměnnými pravidly Brahmy. Hádanka je proto také známá jako Tower of Brahma hádanka. Podle legendy, až bude dokončen poslední tah skládačky, svět skončí.[3]

Pokud by legenda byla pravdivá a kdyby kněží dokázali pohybovat disky rychlostí jeden za sekundu, při použití nejmenšího počtu tahů by jim to trvalo 264 - 1 sekunda nebo zhruba 585 miliarda roky do konce,[4] což je asi 42násobek současného věku vesmíru.

Existuje mnoho variant této legendy. Například v některých sděleních je chrám a klášter a kněží jsou mniši. Dá se říci, že chrám nebo klášter jsou v různých částech světa - včetně Hanoi, Vietnam —A může být spojen s jakýmkoli náboženství. V některých verzích jsou zavedeny další prvky, například skutečnost, že věž byla vytvořena na začátku světa nebo že kněží nebo mniši mohou provést pouze jeden pohyb denně.

Řešení

Hádanku lze hrát na libovolném počtu disků, ačkoli mnoho verzí hraček jich má kolem 7 až 9. Minimální počet tahů potřebných k vyřešení hádanky Tower of Hanoi jsou 2n - 1, kde n je počet disků.[5] To je přesně to nth Mersenne číslo.

Iterační řešení

Animace iteračního algoritmu řešícího problém se 6 disky

Jednoduchým řešením puzzle hračky je střídání pohybů mezi nejmenším dílem a dílem, který není nejmenší. Při přesunu nejmenšího kusu jej vždy přesuňte na další pozici ve stejném směru (doprava, pokud je počáteční počet kusů sudý, doleva, pokud je počáteční počet kusů lichý). Pokud ve zvoleném směru není pozice věže, přesuňte figurku na opačný konec, ale poté pokračujte v pohybu správným směrem. Pokud jste například začali se třemi kusy, přesunuli byste nejmenší kousek na opačný konec a poté pokračovali levým směrem. Když na řadě je tah nejmenšího kusu, existuje pouze jeden legální tah. Tímto způsobem dokončíte hádanku nejmenším počtem tahů.[6]

Jednodušší prohlášení o iterativním řešení

Pro sudý počet disků:

  • provést legální pohyb mezi kolíky A a B (v obou směrech),
  • provést legální pohyb mezi kolíky A a C (v obou směrech),
  • provést legální pohyb mezi kolíky B a C (v obou směrech),
  • opakujte až do dokončení.

Pro lichý počet disků:

  • provést legální pohyb mezi kolíky A a C (v obou směrech),
  • provést legální pohyb mezi kolíky A a B (v obou směrech),
  • provést legální pohyb mezi kolíky B a C (v obou směrech),
  • opakujte až do dokončení.

V obou případech celkem 2n - Provedou se 1 tahy.

Ekvivalentní iterativní řešení

Další způsob, jak vygenerovat jedinečné optimální iterační řešení:

Počet disků 1 až n (od největšího po nejmenší).

  • Li n je lichý, první tah je od kolíku A do kolíku C.
  • Li n je sudý, první tah je z kolíku A do kolíku B.

Nyní přidejte tato omezení:

  • Žádný lichý disk nesmí být umístěn přímo na lichý disk.
  • Žádný sudý disk nesmí být umístěn přímo na sudý disk.
  • Někdy mohou existovat dva možné kolíky: jeden bude mít disky a druhý bude prázdný. Umístěte disk na neprázdný kolík.
  • Nikdy nepohybujte diskem dvakrát za sebou.

Vzhledem k těmto omezením po prvním tahu je v každém dalším tahu pouze jeden legální tah.

Sekvence těchto jedinečných pohybů je optimálním řešením problému ekvivalentního iterativnímu řešení popsanému výše.[7]

Rekurzivní řešení

Ilustrace rekurzivního řešení puzzle Hanojské věže se 4 disky

Klíčem k rekurzivnímu řešení problému je poznání, že jej lze rozdělit na soubor menších dílčích problémů, z nichž každý stejný obecný postup řešení, který hledáme platí a v některých se pak nachází celkové řešení jednoduchý cesta od řešení těchto dílčích problémů. Každý z takto vytvořených dílčích problémů, které jsou „menší“, zaručuje, že budou nakonec dosaženy základní případy. Odtud pro Hanojské věže:

  • označte kolíky A, B, C,
  • nechat n být celkový počet disků,
  • očíslovejte disky od 1 (nejmenší, nejvyšší) do n (největší, nejspodnější).

Za předpokladu všeho n disky jsou distribuovány v platném uspořádání mezi kolíky; za předpokladu, že existují m horní disky na a zdroj kolík a všechny ostatní disky jsou větší než m, takže je lze bezpečně ignorovat; pohybovat se m disky ze zdrojového kolíku do a cílová kolík pomocí a náhradní kolík, aniž by došlo k porušení pravidel:

  1. Hýbat se m - 1 disk z zdroj do náhradní kolík, podle stejný obecný postup řešení. Pravidla nejsou předpokládána. To ponechá disk m jako horní disk na kolíku zdroje.
  2. Přesuňte disk m z zdroj do cílová kolík, který je zaručeně platným tahem, za předpokladu - jednoduchý krok.
  3. Přesuňte m - 1 disky, které jsme právě umístili na náhradní, z náhradní do cílová zavěsit stejný obecný postup řešení, takže jsou umístěny na horní straně disku m aniž by došlo k porušení pravidel.
  4. Základní případ je pohyb 0 disky (v krocích 1 a 3), to znamená nedělat nic - což samozřejmě neporušuje pravidla.

Kompletní řešení Hanojské věže pak spočívá v pohybu n disky ze zdrojového kolíku A do cílového kolíku C s použitím B jako náhradního kolíku.

Tento přístup lze podrobit přísným matematickým důkazem pomocí matematická indukce a často se používá jako příklad rekurze při výuce programování.

Logická analýza rekurzivního řešení

Stejně jako v mnoha matematických hádankách je hledání řešení snazší vyřešením trochu obecnějšího problému: jak přemístit věž h (výška) disky ze startovacího kolíku F = A (z) na cílový kolík t = C (na), B být zbývající třetí věšák a předpokládat tF. Nejprve si všimněte, že problém je symetrický pro permutace jmen kolíků (symetrická skupina S3 ). Pokud je známé řešení, přechází z kolíku A na kolík Cpoté přejmenováním kolíků lze stejné řešení použít pro všechny ostatní volby počátečního a cílového kolíku. Pokud je pouze jeden disk (nebo dokonce vůbec žádný), je problém triviální. Li h = 1, pak jednoduše přesuňte disk z kolíku A na kolík C. Li h > 1, pak někde podél posloupnosti tahů musí být největší disk přesunut z kolíku A na jiný kolík, nejlépe na kolík C. Jediná situace, která tento pohyb umožňuje, je situace, kdy jsou všechny menší h - 1 disk je na kolíku B. Proto nejprve h - 1 menší disk musí jít A na B. Poté přesuňte největší disk a nakonec přesuňte h - 1 menší disk z kolíku B na kolík C. Přítomnost největšího disku nebrání jakémukoli pohybu disku h - 1 menší disk a lze jej dočasně ignorovat. Nyní je problém omezen na pohyb h - 1 disk z jednoho kolíku na druhý, nejprve od A na B a následně od B na C, ale stejnou metodu lze použít oba časy přejmenováním kolíků. Stejnou strategii lze použít ke snížení h - 1 problém h − 2, h - 3 atd., Dokud nezůstane jen jeden disk. Tomu se říká rekurze. Tento algoritmus lze schematizovat následujícím způsobem.

Identifikujte disky v pořadí zvětšování podle přirozených čísel od 0 do, ale ne včetně h. Disk 0 je tedy nejmenší a disk h - 1 největší.

Následuje postup pro přesun věže z h disky z kolíku A na kolík C, s B jako zbývající třetí kolík:

  1. Li h > 1, pak nejprve použijte tento postup k přesunutí h - 1 menší disk z kolíku A na kolík B.
  2. Nyní největší disk, tj. Disk h lze přesunout z kolíku A na kolík C.
  3. Li h > 1, pak znovu použijte tento postup k přesunutí h - 1 menší disk z kolíku B na kolík C.

Prostřednictvím matematická indukce, je snadno prokázáno, že výše uvedený postup vyžaduje minimální možný počet tahů a že vyrobené řešení je jediné s tímto minimálním počtem tahů. Použitím relace opakování, přesný počet tahů, které toto řešení vyžaduje, lze vypočítat podle: . Tohoto výsledku se docílí tím, že se vezme v úvahu kroky 1 a 3 tahy a krok 2 trvá jeden tah, dává .

Rekurzivní implementace

Následující Krajta kód zdůrazňuje základní funkci rekurzivního řešení, která může být jinak nepochopena nebo přehlížena. To znamená, že s každou úrovní rekurze první rekurzivní volání invertuje cílová a pomocný komíny, zatímco ve druhém rekurzivním volání zdroj a pomocný hromádky jsou obrácené.

A = [3, 2, 1]B = []C = []def hýbat se(n, zdroj, cílová, pomocný):    -li n > 0:        # Přesuňte n - 1 disky ze zdroje na pomocné, takže jsou v cestě        hýbat se(n - 1, zdroj, pomocný, cílová)        # Přesuňte n-tý disk ze zdroje do cíle        cílová.připojit(zdroj.pop())        # Zobrazte náš pokrok        tisk(A, B, C, '##############', září=' n')        # Přesuňte disky n - 1, které jsme nechali jako pomocné, na cíl        hýbat se(n - 1, pomocný, cílová, zdroj)# Zahajte hovor ze zdroje A do cíle C pomocí pomocného Bhýbat se(3, A, C, B)

Následující kód implementuje více rekurzivních funkcí pro textovou animaci:

import časA = [i pro i v rozsah(5, 0, -1)]výška = len(A) - 1  # Stabilní hodnota výšky pro animaciB = []C = []def hýbat se(n, zdroj, cílová, pomocný):    -li n > 0:        # Přesuňte n - 1 disky ze zdroje na pomocné, takže jsou v cestě        hýbat se(n - 1, zdroj, pomocný, cílová)        # Přesuňte n-tý disk ze zdroje do cíle        cílová.připojit(zdroj.pop())        # Zobrazte náš pokrok pomocí rekurzivní funkce k jeho vykreslení        draw_disks(A, B, C, výška)        tisk("")  # Zajistěte mezery        čas.spát(0.3)  # Na chvilku pozastavte animaci        # Přesuňte disky n - 1, které jsme nechali jako pomocné, na cíl        hýbat se(n - 1, pomocný, cílová, zdroj)def draw_disks(A, B, C, pozice, šířka=2 * int(max(A))):    Výchozí parametr # width je dvojnásobek největšího disku v původní věži.    -li pozice >= 0:        # Pokud má A v seznamu hodnotu na dané pozici, vytvořte disk na jeho pozici (výška)        hodnotaInA = " " -li pozice >= len(A) jiný create_disk(A[pozice])        # Totéž pro B a C.        hodnotaInB = " " -li pozice >= len(B) jiný create_disk(B[pozice])        hodnotaInC = " " -li pozice >= len(C) jiný create_disk(C[pozice])        # Vytiskněte každý řádek        tisk("{0:^{šířka}}{1:^{šířka}}{2:^{šířka}}".formát(hodnotaInA, hodnotaInB, hodnotaInC, šířka=šířka))        # Rekurzivně volejte tuto metodu znovu na další pozici (výška)        draw_disks(A, B, C, pozice - 1, šířka)    jiný:        # Po dokončení rekurzivního tisku vytiskněte štítky sloupců        tisk("{0:^{šířka}}{1:^{šířka}}{2:^{šířka}}".formát("A", "B", "C", šířka=šířka))def create_disk(velikost):    "" "Jednoduchá rekurzivní metoda pro vytvoření šikmého disku." ""    -li velikost == 1:        vrátit se "/\\"    jiný:        vrátit se "/" + create_disk(velikost - 1) + "\\"# Zahajte hovor ze zdroje A do cíle C pomocí pomocného Bhýbat se(len(A), A, C, B)

Nerekurzivní řešení

Seznam pohybů věže nesené z jednoho kolíku na jiný, jak je vytvořen rekurzivním algoritmem, má mnoho pravidelností. Při počítání tahů počínaje od 1, pořadové číslo disku, které má být přesunuto během pohybu m je počet opakování m lze rozdělit na 2. Proto každý lichý tah zahrnuje nejmenší disk. Lze také pozorovat, že nejmenší disk prochází kolíky F, t, r, F, t, ratd. pro lichou výšku věže a prochází kolíky F, r, t, F, r, tatd. pro rovnoměrnou výšku věže. To poskytuje následující algoritmus, který je jednodušší než ruční rekurzivní algoritmus.

V alternativních tazích:

  • Přesuňte nejmenší disk na kolík, ze kterého nedávno nepocházel.
  • Přesuňte další disk legálně (bude existovat pouze jedna možnost).

Hned při prvním tahu dojde k zablokování nejmenšího disku t -li h je liché a na kolík r -li h je sudý.

Mějte také na paměti, že:

  • Disky, jejichž řadové řádky mají rovnoměrnou paritu, se pohybují ve stejném smyslu jako nejmenší disk.
  • Disky, jejichž ordinály mají lichou paritu, se pohybují v opačném smyslu.
  • Li h je sudý, zbývající třetí kolík během postupných tahů je t, r, F, t, r, F, atd.
  • Li h je liché, zbývající třetí kolík během postupných tahů je r, t, F, r, t, F, atd.

Díky těmto znalostem lze obnovit sadu disků uprostřed optimálního řešení bez dalších informací o stavu, než jsou pozice jednotlivých disků:

  • Volání tahů podrobně popsaných výše označuje „přirozený“ tah disku.
  • Prozkoumejte nejmenší horní disk, který není diskem 0, a všimněte si, jaký by byl jeho jediný (legální) tah: pokud takový disk neexistuje, pak jsme buď na prvním, nebo posledním tahu.
  • Pokud je tento pohyb „přirozeným“ pohybem disku, pak nebyl disk přesunut od posledního tahu disku 0 a tento tah by měl být proveden.
  • Pokud tento pohyb není „přirozeným“ pohybem disku, přesuňte disk 0.

Binární řešení

Pozice disku mohou být určeny přímo z binární (base-2) reprezentace čísla tahu (počáteční stav je tah # 0, se všemi číslicemi 0 a konečný stav se všemi číslicemi 1), pomocí následujících pravidel:

  • Existuje jedna binární číslice (bit ) pro každý disk.
  • Nejvýznamnější bit (nejvíce vlevo) představuje největší disk. Hodnota 0 označuje, že největší disk je na počátečním kolíku, zatímco 1 označuje, že je na konečném kolíku (pravý kolík, pokud je počet disků lichý a jinak střední kolík).
  • Bitstring se čte zleva doprava a každý bit lze použít k určení umístění odpovídajícího disku.
  • Bit se stejnou hodnotou jako předchozí znamená, že odpovídající disk je naskládán na předchozí disk na stejném kolíku.
    (To znamená: přímá posloupnost 1 s nebo 0 s znamená, že všechny odpovídající disky jsou na stejném kolíku.)
  • Bit s jinou hodnotou než předchozí znamená, že odpovídající disk je o jednu pozici nalevo nebo napravo od předchozího. To, zda je vlevo nebo vpravo, určuje toto pravidlo:
    • Předpokládejme, že počáteční kolík je vlevo.
    • Předpokládejme také „zalomení“ - pravý kolík se tedy počítá jako jeden kolík „vlevo“ od levého kolíku a naopak.
    • Nechat n být počet větších disků, které jsou umístěny na stejném kolíku jako jejich první větší disk, a přidat 1, pokud je největší disk na levém kolíku. Li n je sudý, disk je umístěn jeden kolík doprava, pokud n je lichý, disk se nachází jeden kolík doleva (v případě sudého počtu disků a naopak jinak).

Například v 8 discích v Hanoji:

  • Přesunout 0 = 00000000.
    • Největší disk je 0, takže je na levém (počátečním) kolíku.
    • Všechny ostatní disky jsou také 0, takže jsou naskládány na to. Proto jsou všechny disky na počátečním kolíku.
  • Přesunout 28 − 1 = 11111111.
    • Největší disk je 1, takže je na středním (finálním) kolíku.
    • Všechny ostatní disky jsou také 1, takže jsou na sebe naskládané. Proto jsou všechny disky na závěrečném kolíku a hádanka je kompletní.
  • Přesunout 21610 = 11011000.
    • Největší disk je 1, takže je na středním (finálním) kolíku.
    • Disk dva je také 1, takže je naskládán na něj, na střední kolík.
    • Disk tři je 0, takže je na jiném kolíku. Od té doby n je liché (n = 1), je to jeden kolík vlevo, tj. Na levém kolíku.
    • Disk čtyři je 1, takže je na jiném kolíku. Od té doby n je liché (n = 1), je to jeden kolík vlevo, tj. Na pravém kolíku.
    • Disk pět je také 1, takže je naskládán na něj, na pravý kolík.
    • Disk šest je 0, takže je na jiném kolíku. Od té doby n je dokonce (n = 2), disk je jeden kolík doprava, tj. Na levý kolík.
    • Disky sedm a osm jsou také 0, takže jsou naskládány na něj, na levý kolík.

Kolíčky zdroje a cíle pro mTento krok lze také elegantně najít z binární reprezentace m použitím bitové operace. Chcete-li použít syntaxi souboru Programovací jazyk C., hýbat se m je z kolíku (m & m - 1)% 3 na kolík ((m | m - 1) + 1)% 3, kde disky začínají na kolíku 0 a končí na kolíku 1 nebo 2 podle toho, zda je počet disků sudý nebo lichý. Další formulace je z kolíku (m - (m & -m))% 3 na kolík (m + (m & -m))% 3.

Disk, který má být přesunut, je dále určen počtem počtu pohybů (m) lze rozdělit na 2 (tj. počet nulových bitů vpravo), přičemž první tah se počítá jako 1 a disky se identifikují podle čísel 0, 1, 2 atd. v pořadí zvětšování. To umožňuje velmi rychlou nerekurzivní implementaci počítače k ​​vyhledání pozic disků po m pohybech bez odkazu na jakýkoli předchozí pohyb nebo distribuci disků.

Operace, která počítá počet po sobě jdoucích nul na konci binárního čísla, poskytuje jednoduché řešení problému: disky jsou očíslovány od nuly a při pohybu m, číslo disku počítat koncové nuly se posune o minimální možnou vzdálenost doprava (podle potřeby krouží dozadu doleva).[8]

Řešení šedého kódu

Binární číselná soustava Šedé kódy poskytuje alternativní způsob řešení hádanky. V systému Gray jsou čísla vyjádřena v binární kombinaci 0 s a 1 s, ale nikoli jako standard poziční číselná soustava „Šedý kód pracuje na předpokladu, že se každá hodnota liší od svého předchůdce pouze změnou jednoho (a přesně jednoho) bitu.

Pokud jeden počítá v šedém kódu o velikosti bitu rovnající se počtu disků v konkrétní Hanojské věži, začíná na nule a počítá, pak bit změněný každý tah odpovídá disku, který se má pohybovat, kde je nejméně významný bit je nejmenší disk a nejvýznamnější bit je největší.

Počítání tahů od 1 a identifikace disků čísly začínajícími od 0 v pořadí zvětšující se velikosti, pořadové číslo disku, který má být přesunut během pohybu m je počet opakování m lze rozdělit 2.

Tato technika identifikuje, na který disk se má přesunout, ale nikoli kam na něj. Pro nejmenší disk existují vždy dvě možnosti. U ostatních disků existuje vždy jedna možnost, kromě případů, kdy jsou všechny disky na stejném kolíku, ale v takovém případě se musí přesunout buď nejmenší disk, nebo již bylo dosaženo cíle. Naštěstí existuje pravidlo, které říká, kam přesunout nejmenší disk. Nechat F být startovacím kolíkem, t cílový kolík a r zbývající třetí kolík. Pokud je počet disků lichý, nejmenší disk cykluje podél kolíků v pořadí FtrFtr, atd. Pokud je počet disků sudý, musí být obrácen: FrtFrt, atd.[9]

Poloha změny bitu v řešení šedého kódu udává velikost disku přesunutého v každém kroku: 1, 2, 1, 3, 1, 2, 1, 4, 1, 2, 1, 3, 1, 2, 1, ... (sekvence A001511 v OEIS ),[10] sekvence známá také jako funkce pravítka, nebo o jeden více než síla 2 v rámci čísla tahu. V Wolfram jazyk, IntegerExponent [Rozsah [2 ^ 8 - 1], 2] + 1 dává pohyby pro 8-diskovou hádanku.

Grafické znázornění

Hru lze reprezentovat pomocí neorientovaný graf, uzly představující distribuci disků a hrany představující tahy. Pro jeden disk je graf trojúhelník:

Tower of Hanoi 1-disk graph.svg

Graf pro dva disky jsou tři trojúhelníky spojené tak, aby tvořily rohy většího trojúhelníku.

Přidá se druhé písmeno, které představuje větší disk. Je zřejmé, že to zpočátku nelze přesunout.

Nejvyšší malý trojúhelník nyní představuje možnosti jednoho tahu se dvěma disky:

Tower of Hanoi 2-disk graph.svg

Uzly na vrcholech nejvzdálenějšího trojúhelníku představují rozdělení se všemi disky na stejném kolíku.

U disků h + 1 vezměte graf disků h a každý malý trojúhelník nahraďte grafem pro dva disky.

U tří disků je graf:

Tower of Hanoi-3.svg
  • zavolejte kolíky a, b a c
  • seznam pozic disků zleva doprava v pořadí zvětšování

Strany nejvzdálenějšího trojúhelníku představují nejkratší způsoby pohybu věže z jednoho kolíku na druhý. Okraj uprostřed stran největšího trojúhelníku představuje pohyb největšího disku. Okraj uprostřed po stranách každého dalšího menšího trojúhelníku představuje pohyb každého dalšího menšího disku. Strany nejmenších trojúhelníků představují pohyby nejmenšího disku.

Herní graf úrovně 7 ukazuje příbuznost s Sierpińského trojúhelník.

Obecně platí, že pro puzzle s n disky, jsou 3n uzly v grafu; každý uzel má tři hrany k jiným uzlům, kromě tří rohových uzlů, které mají dva: vždy je možné přesunout nejmenší disk na jeden ze dvou dalších kolíků a mezi těmito dvěma kolíky je možné přesunout jeden disk až na v situaci, kdy jsou všechny disky naskládány na jeden kolík. Rohové uzly představují tři případy, kdy jsou všechny disky naskládány na jeden kolík. Schéma pro n + 1 disky se získají pořízením tří kopií disku n-disk diagram - každý představuje všechny stavy a pohyby menších disků pro jednu konkrétní pozici nového největšího disku - a spojuje je v rozích se třemi novými hranami, což představuje pouze tři příležitosti k přesunutí největšího disku. Výsledný údaj má tedy 3n+1 uzly a stále mu zbývají tři rohy s pouhými dvěma hranami.

Jak budou přidány další disky, grafická reprezentace hry bude připomínat a fraktální postava, Sierpińského trojúhelník. Je jasné, že velké většiny pozic v hádance nebude nikdy dosaženo při použití nejkratšího možného řešení; skutečně, pokud kněží legendy používají nejdelší možné řešení (aniž by znovu navštívili jakoukoli pozici), zabere jim to 364 - 1 tah, nebo více než 1023 let.

Nejdelší neopakovatelný způsob pro tři disky lze vizualizovat vymazáním nepoužívaných okrajů:

Tower of Hanoi 3-disk graph - longest path.svg

Mimochodem, tuto nejdelší neopakující se cestu lze získat zakázáním všech tahů z A na b.

The Hamiltonovský cyklus pro tři disky je:

Tower of Hanoi-4 Longest Cycle.svg

Grafy jasně ukazují, že:

  • Z každé libovolné distribuce disků existuje přesně jeden nejkratší způsob, jak přesunout všechny disky na jeden ze tří kolíků.
  • Mezi každou dvojicí libovolných distribucí disků existuje jedna nebo dvě různé nejkratší cesty.
  • Z každé libovolné distribuce disků existuje jedna nebo dvě různé nejdelší cesty bez vlastního křížení, které přesunou všechny disky na jeden ze tří kolíků.
  • Mezi každou dvojicí libovolných distribucí disků existuje jedna nebo dvě různé nejdelší cesty, které se nepřekračují.
  • Nechat Nh být počet nepřekračujících se cest k pohybu věže h disky z jednoho kolíku na druhý. Pak:
    • N1 = 2
    • Nh+1 = (Nh)2 + (Nh)3

To dává Nh být 2, 12, 1872, 6563711232, ... (sekvence A125295 v OEIS )

Variace

Sousední kolíky

Pokud musí být všechny tahy mezi sousedními kolíky (tj. Vzhledem k kolíčkům A, B, C, nelze se pohybovat přímo mezi kolíky A a C), pak přesun hromádky n disky z kolíku A na kolík C jsou 3n - 1 tah. Řešení využívá všechny 3n platné pozice, přičemž vždy vezme jedinečný tah, který nevrátí předchozí tah. Pozice se všemi disky na kolíku B je dosažena do poloviny, tj. Po (3n - 1) / 2 tahy.[Citace je zapotřebí ]

Cyklický Hanoj

V cyklickém Hanoji dostáváme tři kolíky (A, B, C), které jsou uspořádány jako kruh ve směru hodinových ručiček a proti směru hodinových ručiček definovaných jako A - B - C - A a A - C - B - A. Směr pohybu disku musí být ve směru hodinových ručiček.[11] Postačí představovat posloupnost disků, které mají být přesunuty. Řešení lze nalézt pomocí dvou vzájemně rekurzivních postupů:

Přesunout n disky proti směru hodinových ručiček do sousedního cílového kolíku:

  1. hýbat se n - 1 disk proti směru hodinových ručiček k cílovému kolíku
  2. přesunout disk #n jeden krok ve směru hodinových ručiček
  3. hýbat se n - 1 disk ve směru hodinových ručiček na startovací kolík
  4. přesunout disk #n jeden krok ve směru hodinových ručiček
  5. hýbat se n - 1 disk proti směru hodinových ručiček k cílovému kolíku

Přesunout n disky ve směru hodinových ručiček do sousedního cílového kolíku:

  1. hýbat se n - 1 disk proti směru hodinových ručiček na náhradní kolík
  2. přesunout disk #n jeden krok ve směru hodinových ručiček
  3. hýbat se n - 1 disk proti směru hodinových ručiček k cílovému kolíku

Nechť C (n) a A (n) představují pohybující se disky n ve směru hodinových ručiček a proti směru hodinových ručiček, pak můžeme zapsat oba vzorce:

      C (n) = A (n-1) n A (n-1) a A (n) = A (n-1) n C (n-1) n A (n-1).
C (1) = 1 a A (1) = 1 1, C (2) = 1 1 2 1 1 a A (2) = 1 1 2 1 2 1 1.

Řešení pro cyklický Hanoj ​​má několik zajímavých vlastností:

1) Pohybové vzory přenosu věže disků z kolíku na jiný kolík jsou symetrické vzhledem ke středovým bodům.

2) Nejmenší disk je první a poslední disk, který se má přesunout.

3) Skupiny nejmenších tahů disku se střídají s jednotlivými tahy jiných disků.

4) Počet pohybů disků specifikovaných C (n) a A (n) je minimální.

Se čtyřmi kolíky a dále

Ačkoli verze se třemi kolíky má již dlouho známé jednoduché rekurzivní řešení, optimální řešení problému Tower of Hanoi se čtyřmi kolíky (tzv. Reveova skládačka) nebylo ověřeno až do roku 2014, Bouschem.[12]

V případě čtyř nebo více kolíků je však algoritmus Frame-Stewart známý bez důkazu optimality od roku 1941.[13]

Formální odvození přesného počtu minimálních tahů potřebných k vyřešení problému použitím algoritmu Frame – Stewart (a dalších ekvivalentních metod) najdete v následujícím příspěvku.[14]

Další varianty problému se čtyřmi kolíky z Hanojské věže najdete v průzkumném příspěvku Paula Stockmeyera.[15]

Algoritmus Frame – Stewart

Algoritmus Frame – Stewart je popsán níže:

  • Nechat být počet disků.
  • Nechat být počet kolíků.
  • Definovat jako minimální počet tahů potřebných k přenosu n disků pomocí r pegů.

Algoritmus lze popsat rekurzivně:

  1. Pro některé , , přeneste horní část disky na jeden kolík jiný než počáteční nebo cílové kolíky, přičemž tahy.
  2. Bez narušení kolíku, který nyní obsahuje vrchol disky, přeneste zbývající disky k cílovému kolíku, použije pouze zbývající kolíčky, přičemž tahy.
  3. Nakonec přeneste horní část disky do cílového kolíku, přičemž tahy.

Celý proces trvá tahy. Proto počet je třeba vybrat, pro které je toto množství minimální. V případě 4-kolíku optimální rovná se , kde je nejbližší celočíselná funkce.[16] Například v kurzu UPenn CIS 194 na Haskellu, první stránka s úkoly[17] uvádí optimální řešení pro případ 15 disků a 4 kolíků jako 129 kroků, které jsou získány pro výše uvedenou hodnotu k.

Předpokládá se, že tento algoritmus je optimální pro libovolný počet kolíků; jeho počet tahů je 2Θ (n1/(r−2)) (pro pevné r).

Obecně nejkratší cesty a číslo 466/885

Zajímavým zobecněním původního cíle skládačky je začít od dané konfigurace disků, kde všechny disky nemusí být nutně na stejném kolíku, a dosáhnout minimálního počtu tahů v jiné dané konfiguraci. Obecně může být docela obtížné vypočítat nejkratší sled tahů k vyřešení tohoto problému. Řešení navrhl Andreas Hinz a je založeno na pozorování, že v nejkratší posloupnosti tahů je největší disk, který je třeba přesunout (samozřejmě jeden může ignorovat všechny největší disky, které obsadí stejný kolík v obou počátečních a finální konfigurace) se bude pohybovat buď přesně jednou, nebo přesně dvakrát.

Matematika související s tímto obecným problémem se stává ještě zajímavější, když vezmeme v úvahu průměrný počet tahů v nejkratší posloupnosti tahů mezi dvěma počátečními a posledními konfiguracemi disku, které jsou vybrány náhodně. Hinz a Chan Tat-Hung nezávisle objevili[18][19] (viz také[20]:Kapitola 1, str. 14), že průměrný počet tahů v n-disk Tower je dán následujícím přesným vzorcem:

Pro dostatečně velké n, pouze první a druhý člen nesblíží na nulu, takže dostaneme asymptotický výraz: , tak jako . Takto intuitivně bychom mohli interpretovat zlomek jako představující poměr práce, kterou člověk musí provést při přechodu z náhodně vybrané konfigurace do jiné náhodně vybrané konfigurace, vzhledem k obtížnosti nutnosti překonat „nejobtížnější“ délkovou cestu což zahrnuje přesun všech disků z jednoho kolíku na druhý. Alternativní vysvětlení vzhledu konstanty 466/885, stejně jako nový a poněkud vylepšený algoritmus pro výpočet nejkratší cesty, podal Romik.[21]

Magnetický Hanoj

V magnetické věži v Hanoji má každý disk dvě odlišné strany na sever a na jih (obvykle zbarvené „červené“ a „modré“). Disky nesmí být umístěny společně s podobnými póly - magnety na každém disku brání tomuto nelegálnímu pohybu. Každý také disk musí být při pohybu převrácen.

Počáteční konfigurace dvoubarevných věží v Hanoji (n = 4)

Bicolor Towers of Hanoi

Tato variace slavné hádanky z Hanoje byla nabídnuta studentům ve třídě 3–6 na 2ème Championnat de France des Jeux Mathématiques et Logiques se konalo v červenci 1988.[22]

Konečná konfigurace dvoubarevných věží v Hanoji (n = 4)

Pravidla skládačky jsou v zásadě stejná: disky se přenášejí mezi kolíky jeden po druhém. Větší disk nesmí být nikdy umístěn na menší disk. Rozdíl je v tom, že nyní pro každou velikost existují dva disky: jeden černý a jeden bílý. Nyní jsou zde také dvě věže disků střídajících se barev. Cílem této hádanky je vytvořit věže jednobarevné (stejné barvy). Předpokládá se, že největší disky ve spodní části věží si vyměňují pozice.

Hanojská věž

Varianta skládačky byla upravena jako solitairová hra s devíti hracími kartami pod jménem Hanojská věž.[23][24] Není známo, zda je změněný pravopis původního názvu úmyslný nebo náhodný.[25]

Aplikace

3D topografický obraz AFM vícevrstvého nanosheet palladia na křemíkové desce, se strukturou podobnou věži z Hanoje.[26]

Hanojská věž se často používá v psychologickém výzkumu řešení problému. Existuje také varianta tohoto úkolu s názvem Londýnský Tower pro neuropsychologickou diagnostiku a léčbu výkonných funkcí.

Zhang a Norman[27] použil několik izomorfních (ekvivalentních) reprezentací hry ke studiu dopadu reprezentačního efektu při navrhování úkolů. Ukázali dopad na výkon uživatele změnou způsobu, jakým jsou pravidla hry reprezentována, pomocí variací ve fyzickém designu herních komponent. Tyto znalosti ovlivnily vývoj rámce TURF[28] pro zastoupení interakce člověka s počítačem.

Hanojská věž se také používá jako schéma střídání záloh při provádění počítačových dat zálohy kde je zapojeno více pásek / médií.

Jak již bylo zmíněno výše, Hanojská věž je populární pro výuku rekurzivních algoritmů pro začínající studenty programování. Obrázková verze této hádanky je naprogramována do emacs editor, přístupný zadáním M-x hanoi. Je také napsán ukázkový algoritmus Prolog.

Hanojská věž je také používána jako test neuropsychologů, kteří se snaží vyhodnotit čelní lalok deficity.[29]

V roce 2010 vědci zveřejnili výsledky experimentu, který zjistil, že druh mravence Linepithema humile byli úspěšně schopni vyřešit 3-diskovou verzi problému Hanojské věže pomocí nelineární dynamiky a feromonových signálů.[30]

V roce 2014 vědci syntetizovali vícevrstvé palladiové nanosety se strukturou podobnou Hanojské věži.[26]

V populární kultuře

V příběhu sci-fi "Nyní se nadechněte", autor Eric Frank Russell,[31] člověk je držen v zajetí na planetě, kde je místním zvykem přimět vězně hrát hru, dokud není vyhrána nebo ztracena před jeho popravou. Hlavní hrdina ví, že záchranná loď může dorazit rok i déle, a tak se rozhodl zahrát si Hanojské věže se 64 disky. (Tento příběh odkazuje na legendu o buddhistických mnichech hrajících hru až do konce světa.)

V roce 1966 Doktor kdo příběh Nebeský hračkář, stejnojmenný darebácké síly lékař hrát desetidílnou hru Tower of Hanoi s názvem 1023 tahů Trilogická hra s kusy, které po stohování tvoří tvar pyramidy.

V roce 2007 byl koncept problému Towers Of Hanoi použit v Profesor Layton a ďábelská skříňka v hádankách 6, 83 a 84, ale disky byly změněny na palačinky. Hádanka byla založena na dilematu, kdy šéfkuchař restaurace musel přesouvat hromadu palačinek z jednoho talíře na druhý se základními principy původního puzzle (tj. Tři talíře, na které bylo možné palačinky přesunout, aniž by byli schopni položte větší palačinku na menší atd.)

Ve filmu Rise of the Planet of the Apes (2011), tato hádanka, která se ve filmu nazývá „Lucasova věž“, se používá jako test ke studiu inteligence lidoopů.

Hádanka je pravidelně uváděna v dobrodružství a hádanka hry. Vzhledem k tomu, že je snadno implementovatelný a snadno rozpoznatelný, je vhodný pro použití jako logická hra ve větší grafické hře (např. Star Wars: Knights of the Old Republic a Hromadný efekt ).[32] Některé implementace používají přímé disky, ale jiné maskují hádanku v jiné formě. K dispozici je arkádová verze od Sega.[33]

Ve hře se objeví verze puzzle s 15 disky Moře bez slunce jako zámek k hrobce. The player has the option to click through each move of the puzzle in order to solve it, but the game notes that it will take 32767 moves to complete. If an especially dedicated player does click through to the end of the puzzle, it is revealed that completing the puzzle does not unlock the door.

v Yu-Gi-Oh! VLAINY, a hacking group called "Knight of Hanoi" create a structure named "Tower of Hanoi" within the eponymous VRAINS virtual reality network.

This was first used as a challenge in survivor Thailand in 2002 but rather than rings, the pieces were made to resemble a temple. Sook Jai threw the challenge to get rid of Jed even though Shii-Ann knew full well how to complete the puzzle.The problem is featured as part of a reward challenge in a 2011 episode of the American version of the Pozůstalý Televizní seriál. Both players (Ozzy Lusth a Benjamin „Trenér“ Wade ) struggled to understand how to solve the puzzle and are aided by their fellow tribe members.

Viz také

Poznámky

  1. ^ Hofstadter, Douglas R. (1985). Metamagical Themas : Questing for the Essence of Mind and Pattern. New York: Základní knihy. ISBN  978-0-465-04540-2.
  2. ^ Hinz, Andreas M .; Klavžar, Sandi; Milutinović, Uroš; Petr, Ciril (2013-01-31). Hanojská věž - mýty a matematika. ISBN  978-3034802369.
  3. ^ Spitznagel, Edward L. (1971). Selected topics in mathematics. Holt, Rinehart a Winston. p.137. ISBN  978-0-03-084693-9.
  4. ^ Moscovich, Ivan (2001). 1000 playthinks: puzzles, paradoxes, illusions & games. Dělník. ISBN  978-0-7611-1826-8.
  5. ^ Petković, Miodrag (2009). Slavné hádanky velkých matematiků. AMS Bookstore. p. 197. ISBN  978-0-8218-4814-2.
  6. ^ Troshkin, M. "Doomsday Comes: A Nonrecursive Analysis of the Recursive Towers-of-Hanoi Problem". Soustředit se (v Rusku). 95 (2): 10–14.
  7. ^ Mayer, Herbert; Perkins, Don (1984). "Towers of Hanoi Revisited". Oznámení SIGPLAN. 19 (2): 80–84. doi:10.1145/948566.948573. S2CID  2304761.
  8. ^ Warren, Henry S. (2003). "Section 5-4: Counting Trailing 0's.". Hacker's delight (1. vyd.). Boston MA: Addison-Wesley. ISBN  978-0-201-91465-8.
  9. ^ Miller, Charles D. (2000). "Ch. 4: Binary Numbers and the Standard Gray Code". Mathematical Ideas (9 ed.). Addison Wesley Longman. ISBN  978-0-321-07607-6. Archived from the original on 2004-08-21.CS1 maint: BOT: stav původní adresy URL neznámý (odkaz)
  10. ^ Gros, L. (1872). Théorie du Baguenodier. Lyon: Aimé Vingtrinier.
  11. ^ Gedeon, T. D. (1996). "The Cyclic Towers of Hanoi: An Iterative Solution Produced by Transformation". Počítačový deník. 39 (4): 353–356. doi:10.1093/comjnl/39.4.353.
  12. ^ Bousch, T. (2014). "La quatrieme tour de Hanoi" (PDF). Býk. Belg. Matematika. Soc. Simon Stevin. 21: 895–912. doi:10.36045/bbms/1420071861. S2CID  14243013.
  13. ^ Stewart, B. M.; Frame, J. S. (March 1941). "Solution to advanced problem 3819". Americký matematický měsíčník. 48 (3): 216–9. doi:10.2307/2304268. JSTOR  2304268.
  14. ^ Klavzar, Sandi; Milutinovi, Uro; Petrb, Ciril (2002). "Variations on the Four-Post Tower of Hanoi Puzzle" (Postscript). Congressus Numerantium. 102.
  15. ^ Stockmeyer, Paul (1994). "Variations on the Four-Post Tower of Hanoi Puzzle" (Postscript). Congressus Numerantium. 102: 3–12.
  16. ^ "University of Toronto CSC148 Slog". 5. dubna 2014. Citováno 22. července 2015.
  17. ^ "UPenn CIS 194 Introduction to Haskell Assignment 1" (PDF). Citováno 31. ledna 2016.
  18. ^ Hinz, A. (1989). "The Tower of Hanoi". L'Enseignement Mathématique. 35: 289–321. doi:10.5169/seals-57378.
  19. ^ Chan, T. (1988). "A statistical analysis of the towers of Hanoi problem". Internat. J. Comput. Matematika. 28 (1–4): 57–65. doi:10.1080/00207168908803728.
  20. ^ Stewart, Ian (2004). Another Fine Math You've Got Me Into... Courier Dover. ISBN  978-0-7167-2342-4.
  21. ^ Romik, D. (2006). "Shortest paths in the Tower of Hanoi graph and finite automata". SIAM Journal on Discrete Mathematics. 20 (3): 610–622. arXiv:math/0310109. doi:10.1137/050628660. S2CID  8342396.
  22. ^ Prasad Vithal Chaugule (2015). "A Recursive Solution to Bicolor Towers of Hanoi Problem" (PDF). Recreational Mathematics Magazine (4): 37–48. ISSN  2182-1976.
  23. ^ Arnold, Peter (2003-05-28). Card Games for One. Nakladatelská společnost Sterling. ISBN  978-0-600-60727-4.
  24. ^ Hedges, Sid G. (2018-03-06). Everybody's Book of Hobbies. Read Books Ltd. ISBN  978-1-5287-8344-6.
  25. ^ "Tower Of Hanoy Patience (AKA Tower Of Hanoi Patience)". bbcmicro.co.uk. Citováno 2020-10-17.
  26. ^ A b Yin, Xi; Liu, Xinhong; Pan, Yung-Tin; Walsh, Kathleen A.; Yang, Hong (November 4, 2014). "Hanoi Tower-like Multilayered Ultrathin Palladium Nanosheets". Nano dopisy. 14 (12): 7188–94. Bibcode:2014NanoL..14.7188Y. doi:10.1021/nl503879a. PMID  25369350.
  27. ^ Zhang, J (1994). "Representations in distributed cognitive tasks" (PDF). Kognitivní věda. 18: 87–122. doi:10.1016/0364-0213(94)90021-3.
  28. ^ Zhang, Jiajie; Walji, Muhammad F. (2011). "TURF: Toward a unified framework of EHR usability". Časopis biomedicínské informatiky. 44 (6): 1056–67. doi:10.1016/j.jbi.2011.08.005. PMID  21867774.
  29. ^ Beers, S. R.; Rosenberg, D. R.; Dick, E. L.; Williams, T .; O'Hearn, K. M.; Birmaher, B.; Ryan, C. M. (1999). "Neuropsychological study of frontal lobe function in psychotropic-naive children with obsessive-compulsive disorder". American Journal of Psychiatry. 156 (5): 777–9. doi:10.1176/ajp.156.5.777 (neaktivní 2020-12-05). PMID  10327915.CS1 maint: DOI neaktivní od prosince 2020 (odkaz)
  30. ^ Reid, C.R.; Sumpter, D.J.; Beekman, M. (January 2011). "Optimisation in a natural system: Argentine ants solve the Towers of Hanoi". J. Exp. Biol. 214 (Pt 1): 50–8. CiteSeerX  10.1.1.231.9201. doi:10.1242/jeb.048173. PMID  21147968. S2CID  18819977.
  31. ^ Russell, Eric Frank (April 1959). "Now Inhale". Ohromující sci-fi.
  32. ^ "Tower of Hanoi (video game concept)". Giantbomb.com. Citováno 2010-12-05.
  33. ^ "Tower of Hanoi / Andamiro". Sega Amusements. Archivovány od originál dne 01.03.2012. Citováno 2012-02-26.

externí odkazy