python绘制汉诺塔


Posted in Python onMarch 01, 2021

本文实例为大家分享了python绘制汉诺塔的具体代码,供大家参考,具体内容如下

源码:

import turtle
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_3(): # 画出汉诺塔的poles
  t = turtle.Turtle()
  t.hideturtle()
  def drawpole_1(k):
    t.up()
    t.pensize(10)
    t.speed(100)
    t.goto(400 * (k - 1), 100)
    t.down()
    t.goto(400 * (k - 1), -100)
    t.goto(400 * (k - 1) - 20, -100)
    t.goto(400 * (k - 1) + 20, -100)
  drawpole_1(0) # 画出汉诺塔的poles[0]
  drawpole_1(1) # 画出汉诺塔的poles[1]
  drawpole_1(2) # 画出汉诺塔的poles[2]
def creat_plates(n): # 制造n个盘子
  plates = [turtle.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的栈
  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 = turtle.Screen()
drawpole_3()
n = int(input("请输入汉诺塔的层数并回车:\n"))
plates = creat_plates(n)
poles = pole_stack()
for i in range(n):
  poles[0].push(i)
moveTower(plates, poles, n, 0, 2, 1)
myscreen.exitonclick()

效果图:

python绘制汉诺塔

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
wxPython窗口中文乱码解决方法
Oct 11 Python
Python中非常实用的一些功能和函数分享
Feb 14 Python
python中urllib.unquote乱码的原因与解决方法
Apr 24 Python
Python过滤txt文件内重复内容的方法
Oct 21 Python
基于Python实现人脸自动戴口罩系统
Feb 06 Python
python GUI库图形界面开发之PyQt5时间控件QTimer详细使用方法与实例
Feb 26 Python
使用 Python ssh 远程登陆服务器的最佳方案
Mar 06 Python
PyQt5如何将.ui文件转换为.py文件的实例代码
May 26 Python
tensorflow图像裁剪进行数据增强操作
Jun 30 Python
python实现图像外边界跟踪操作
Jul 13 Python
Python爬虫之爬取淘女郎照片示例详解
Jul 28 Python
python 装饰器的基本使用
Jan 13 Python
彻底解决pip下载pytorch慢的问题方法
Mar 01 #Python
Python 里最强的地图绘制神器
Mar 01 #Python
Python的collections模块真的很好用
Mar 01 #Python
Python  Asyncio模块实现的生产消费者模型的方法
Mar 01 #Python
Python创建自己的加密货币的示例
Mar 01 #Python
python 实现网易邮箱邮件阅读和删除的辅助小脚本
Mar 01 #Python
详解Django中的FBV和CBV对比分析
Mar 01 #Python
You might like
这部好评如潮的动漫 知名梗频出 但是画风劝退很多人
2020/03/08 日漫
使用 eAccelerator加速PHP代码的目的
2007/03/16 PHP
PHP中=赋值操作符对不同数据类型的不同行为
2011/01/02 PHP
php中socket的用法详解
2014/10/24 PHP
详解PHP使用Redis存储session时的一个Warning定位
2017/07/05 PHP
PHP面向对象五大原则之里氏替换原则(LSP)详解
2018/04/08 PHP
PHP实现微信商户支付企业付款到零钱功能
2018/09/30 PHP
PHP大文件分块上传功能实例详解
2019/07/22 PHP
thinkPHP5框架路由常用知识点汇总
2019/09/15 PHP
php实现文件上传基本验证
2020/03/04 PHP
jQuery实现单行文字间歇向上滚动源代码
2013/06/02 Javascript
JS去除右边逗号的简单方法
2013/07/03 Javascript
JavaScript 操作table,可以新增行和列并且隔一行换背景色代码分享
2013/07/05 Javascript
等待指定时间后自动跳转或关闭当前页面的js代码
2013/07/09 Javascript
JQuery简单实现锚点链接的平滑滚动
2015/05/03 Javascript
JSON简介以及用法汇总
2016/02/21 Javascript
vue.js表格分页示例
2016/10/18 Javascript
Vue.js中用v-bind绑定class的注意事项
2016/12/13 Javascript
详解webpack2+node+react+babel实现热加载(hmr)
2017/08/24 Javascript
vue图片加载失败时用默认图片替换的方法
2019/08/29 Javascript
[08:02]DOTA2牵红线 zhou神抱得美人归
2014/03/22 DOTA
[01:20]DOTA2 2017国际邀请赛冠军之路无止竞
2017/06/19 DOTA
Python和Ruby中each循环引用变量问题(一个隐秘BUG?)
2014/06/04 Python
Python的Django框架中的URL配置与松耦合
2015/07/15 Python
python爬虫selenium和phantomJs使用方法解析
2019/08/08 Python
Python3操作Excel文件(读写)的简单实例
2019/09/02 Python
Python namedtuple命名元组实现过程解析
2020/01/08 Python
Django之全局使用request.user.username的实例详解
2020/05/14 Python
Python使用configparser读取ini配置文件
2020/05/25 Python
Python matplotlib读取excel数据并用for循环画多个子图subplot操作
2020/07/14 Python
Python二元算术运算常用方法解析
2020/09/15 Python
Python基于argparse与ConfigParser库进行入参解析与ini parser
2021/02/02 Python
奥地利度假券的专家:we-are.travel
2019/04/10 全球购物
五水共治捐款倡议书
2014/05/14 职场文书
国际语言毕业生求职信
2014/07/08 职场文书
2015年打非治违工作总结
2015/04/02 职场文书