Maison >développement back-end >Tutoriel Python >Comment implémenter le problème de la Tour de Hanoï en utilisant Python

Comment implémenter le problème de la Tour de Hanoï en utilisant Python

王林
王林avant
2023-05-15 17:31:063442parcourir

Avant-propos

Le problème de la Tour de Hanoï est un problème classique. La tour de Hanoï, également connue sous le nom de tour de Hanoï, tire son origine d'une ancienne légende indienne. Lorsque Brahma a créé le monde, il a construit trois piliers de diamant. Sur un pilier, 64 disques d'or ont été empilés par ordre de taille, de bas en haut. Brahma a ordonné au brahmane de réorganiser les disques sur un autre pilier par ordre de taille à partir du bas. Il est également stipulé qu'à aucun moment, le disque ne peut être agrandi sur le petit disque, et qu'un seul disque peut être déplacé entre les trois piliers à la fois. Demandez comment fonctionner?

1. Parlons d’abord de ce qu’est la récursion ?

Ma propre compréhension est la suivante : continuez à réduire la taille de vos propres problèmes jusqu'à ce qu'ils soient réduits au point où ils ne peuvent plus être réduits. (La condition finale de la récursion est atteinte) Commencez ensuite à résoudre les petits problèmes. Après avoir résolu les petits problèmes un par un, le gros problème sera résolu (la récursion est de retour)

2. est continuellement réduit à une échelle plus petite du problème d'origine, puis le problème d'origine à petite échelle est résolu, résolvant ainsi le grand problème d'origine !

3. Le processus est le suivant :

Réduire l'échelle, la résoudre à partir d'une petite taille, revenir en arrière et résoudre le problème d'origine ! ! !

4. La clé de la récursivité est :

(1) Il existe une condition de fin de récursion.

(2) S'appeler constamment pour réduire la taille du problème et se rapprocher de la condition finale de la récursion.

Problème de la Tour de Hanoï

1. Description du problème

Il y a trois piliers nommés A, B et C. Initialement, il y a n disques sur le pilier A, ils sont de bas en haut et la taille des disques va de grand à petit. Lors du déplacement et du placement, les petites plaques doivent être au-dessus des grandes plaques. Tout en respectant les règles, déplacez toutes les plaques du pilier A vers le pilier C. Vous pouvez utiliser le pilier B pendant le déplacement, mais vous devez vous assurer que les petites plaques doivent être sur les grandes plaques pendant le déménagement ! ! ! Veuillez imprimer le processus de déménagement ?

Comment implémenter le problème de la Tour de Hanoï en utilisant Python2. Processus récursif d'analyse des problèmes :

(1) Déplacez les n-1 plaques supérieures de A à B à l'aide de C

(2) Déplacez la plaque inférieure de A à C

(3 ) Déplacez les n-1 plaques supérieures de B à C à l'aide de A

La condition finale de la récursion :

L'échelle du problème devient lorsque le nombre de plaques est 0, car lorsque le nombre de plaques est 0 Pas besoin bouger! ! !

3. Code (Python)

# coding:utf-8

"""
    n为初始时A柱上的盘子数
    a为起始盘子所在的柱子
    b为中转柱子
    c为目的地柱子
"""


def hanoi(n, a, b, c):
    if n > 0:
        hanoi(n-1, a, c, b)
        print("盘子从%s移动到%s" % (a, c))
        hanoi(n-1, b, a, c)



hanoi(3, "A", "B", "C")

4. Affichage des résultats

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer