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')
  • 相关阅读:
    2020年9月29日
    随机生成验证码
    动手动脑java语法基础
    Java语法之动手实验
    代码大全2 读书笔记
    java动手动动脑之字串联接
    二柱子问题
    生成随机四则运算1
    可变参数
    2020年9月30日
  • 原文地址:https://www.cnblogs.com/love528/p/9901855.html
Copyright © 2011-2022 走看看