zoukankan      html  css  js  c++  java
  • 用python实现汉诺塔

    汉诺塔问题描述:

      汉诺塔:汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘

    实现方法:递归

      如果a只有一个圆盘,可以直接移动到c; 
      如果a有N个圆盘,可以看成a有1个圆盘(底盘) + (N-1)个圆盘,首先需要把 (N-1) 个圆盘移动到 b,然后,将 a的最后一个圆盘移动到c,再将b的(N-1)个圆盘移动到c。 

    代码实现:

    def move(n, a, b, c):
        if n==1:
            print a,'-->',c
            return
        else:
            move(n-1,a,c,b)  #首先需要把 (N-1) 个圆盘移动到 b
            move(1,a,b,c)    #将a的最后一个圆盘移动到c
            move(n-1,b,a,c)  #再将b的(N-1)个圆盘移动到c
    move(4, 'A', 'B', 'C')
  • 相关阅读:
    贪心法之最优装载问题
    判断回文
    P1217 [USACO1.5]回文质数 Prime Palindromes
    李白打酒
    P1036 选数
    P1028 数的计算
    P1316 丢瓶盖
    P1181 数列分段Section I
    P1182 数列分段`Section II`
    P1216 [IOI1994][USACO1.5]数字三角形 Number Triangles
  • 原文地址:https://www.cnblogs.com/love528/p/9901855.html
Copyright © 2011-2022 走看看