博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python 游戏 —— 汉诺塔(Hanoita)
阅读量:4641 次
发布时间:2019-06-09

本文共 2837 字,大约阅读时间需要 9 分钟。

一、汉诺塔问题

1. 问题来源

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

2. 问题阐述

  塔内有三个座A、B、C,A座上有64个盘子,盘子从上到下逐渐变大,最下面的盘子最大。目前要把A座的64个盘子从A座移到C座,并且每次只能移动一个盘子,移动过程中三个座保持大盘子在下,小盘子在上,要求输出盘子的移动过程。

 

二、问题解析

1. 解决方法:递归方法

2. 解题过程

  (1) 将上面63个盘子从A座移到B座

  (2) 将最下面的盘子从A座移到C座

  (3) 将B座的63个盘子从B座移到C座

 

三、问题解决

1. 非可视化解决

  (1) 代码实现

''' 编程环境:python3.7  win7x64 '''  def printf(A,C):  #盘子移动的输出格式      print("{} --> {}".format(A,C))    def move(n,A,B,C):      if n == 1:          printf(A,C)     #将最后1个盘子从A座移到C座      else:          move(n-1,A,C,B) #将n个盘子从A座借助B座移到C座         printf(A,C)     #将最后1个盘子从A座移到C座         move(n-1,B,A,C) #将n个盘子从B座借助A座移到C座  N = int(input("请输入汉诺塔层数:")) move(N,'A','B','C')

  (2) 有图有真相

 

2. 可视化解决

   (1) 代码实现

''' 编程环境:python3.7  win7x64 '''  from turtle import *  class Stack:      def __init__(self):          self.items = []      def isEmpty(self):          return len(self.items) == 0      def push(self, item):          self.items.append(item)     def pop(self):         return self.items.pop()     def peek(self):         if not self.isEmpty():             return self.items[len(self.items) - 1]     def size(self):         return len(self.items)  def drawpole_1(k):#画汉诺塔的底座     up()     pensize(10)     speed(100)     goto(400*(k-1), 100)     down()     goto(400*(k-1), -100)     goto(400*(k-1)-20, -100)     goto(400*(k-1)+20, -100)  def drawpole_3():#画出汉诺塔的三个底座     hideturtle()#隐藏     drawpole_1(0)#画出汉诺塔的底座左     drawpole_1(1)#画出汉诺塔的底座中     drawpole_1(2)#画出汉诺塔的底座右 def creat_plates(n):#制造n个盘子     plates=[Turtle() for i in range(n)]     for i in range(n):         plates[i].up()         plates[i].hideturtle()         plates[i].shape("square")         plates[i].shapesize(1,8-i)         plates[i].goto(-400,-90+20*i)         plates[i].showturtle()     return plates  def pole_stack():#制造底座的栈     poles=[Stack() for i in range(3)]     return poles  def moveDisk(plates,poles,fp,tp):#把poles[fp]顶端的盘子plates[mov]从poles[fp]移到poles[tp]     mov=poles[fp].peek()     plates[mov].goto((fp-1)*400,150)     plates[mov].goto((tp-1)*400,150)     l=poles[tp].size()#确定移动到底部的高度(恰好放在原来最上面的盘子上面)     plates[mov].goto((tp-1)*400,-90+20*l)  def moveTower(plates,poles,height,fromPole, toPole, withPole):#递归放盘子     if height >= 1:         moveTower(plates,poles,height-1,fromPole,withPole,toPole)         moveDisk(plates,poles,fromPole,toPole)         poles[toPole].push(poles[fromPole].pop())         moveTower(plates,poles,height-1,withPole,toPole,fromPole)  myscreen=Screen() setup(1200,500) #设置窗口大小 drawpole_3()    #画汉诺塔的底座 n=int(input("请输入汉诺塔的层数并回车:"))#输入汉诺塔的盘子数 plates=creat_plates(n)#制造n个盘子 poles=pole_stack() for i in range(n):     poles[0].push(i) moveTower(plates,poles,n,0,2,1) myscreen.exitonclick()

  

        (2) 有图有真相

 

转载于:https://www.cnblogs.com/elbow/p/10604736.html

你可能感兴趣的文章
IE常见BUG总结(持续更新)
查看>>
php 文件操作
查看>>
Java内存区域划分、内存分配原理(转)
查看>>
6.5日讲课——dp动态规划
查看>>
16.2 【C# 5】调用者信息特性
查看>>
Spring之IOC容器加载初始化的方式
查看>>
1 为什么搭建.Net core下的云开发框架
查看>>
Java安全防御学习笔记V1.0
查看>>
Python时间和日期
查看>>
oracle 11g ocp 笔记(26)--全球化
查看>>
bzoj3712: [PA2014]Fiolki
查看>>
asp.net 淘宝api获取商品信息
查看>>
宏_CRTIMP分析
查看>>
ubuntu创建、删除文件及文件夹,强制清空回收站方法
查看>>
jmeter参数化之CSV Data Set Config
查看>>
Cobbler--自动化部署
查看>>
diff
查看>>
linux源码Makefile详解
查看>>
css3圈圈进度条
查看>>
【linux配置】在VMware中为Redhat HAT配置本地yum源
查看>>