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 相关文章推荐
浅谈python可视化包Bokeh
Feb 07 Python
python批量导入数据进Elasticsearch的实例
May 30 Python
python写入并获取剪切板内容的实例
May 31 Python
Python中list查询及所需时间计算操作示例
Jun 21 Python
使用Python向DataFrame中指定位置添加一列或多列的方法
Jan 29 Python
python opencv minAreaRect 生成最小外接矩形的方法
Jul 01 Python
Django基础知识 URL路由系统详解
Jul 18 Python
使用python脚本自动创建pip.ini配置文件代码实例
Sep 20 Python
解决Tensorboard可视化错误:不显示数据 No scalar data was found
Feb 15 Python
django admin后管定制-显示字段的实例
Mar 11 Python
python字典key不能是可以是啥类型
Aug 04 Python
pd.drop_duplicates删除重复行的方法实现
Jun 16 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
PHP查询MySQL大量数据的时候内存占用分析
2011/07/22 PHP
php多个文件及图片上传实例详解
2014/11/10 PHP
THINKPHP内容分页代码分享
2015/01/14 PHP
利用PHP访问MySql数据库的逻辑操作以及增删改查的实例讲解
2017/08/30 PHP
JCalendar 日历控件 v1.0 beta[兼容IE&Firefox] 有文档和例子
2007/05/30 Javascript
jquery实现表格奇数偶数行不同样式(有图为证及实现代码)
2013/01/23 Javascript
取消选中单选框radio的三种方式示例介绍
2013/12/23 Javascript
javascript编写贪吃蛇游戏
2015/07/07 Javascript
jQuery实现的fixedMenu下拉菜单效果代码
2015/08/24 Javascript
jQuery解析json数据实例分析
2015/11/24 Javascript
jQuery插件实现表格隔行变色及鼠标滑过高亮显示效果代码
2016/02/25 Javascript
浅谈js内置对象Math的属性和方法(推荐)
2016/09/19 Javascript
原生js实现倒计时功能(多种格式调用)
2017/01/12 Javascript
vue与bootstrap实现时间选择器的示例代码
2017/08/26 Javascript
利用nginx + node在阿里云部署https的步骤详解
2017/12/19 Javascript
vue项目中使用tinymce编辑器的步骤详解
2018/09/11 Javascript
微信小程序公用参数与公用方法用法示例
2019/01/09 Javascript
p5.js临摹动态图形实现方法详解
2019/10/23 Javascript
[55:16]Mski vs VGJ.S Supermajor小组赛C组 BO3 第二场 6.3
2018/06/04 DOTA
python实现排序算法
2014/02/14 Python
Python实现根据指定端口探测服务器/模块部署的方法
2014/08/25 Python
python使用urllib2实现发送带cookie的请求
2015/04/28 Python
两个命令把 Vim 打造成 Python IDE的方法
2016/03/20 Python
Python实现可自定义大小的截屏功能
2018/01/20 Python
深入浅析Python 函数注解与匿名函数
2020/02/24 Python
Python3 利用face_recognition实现人脸识别的方法
2020/03/13 Python
HTML5 progress和meter控件_动力节点Java学院整理
2017/07/06 HTML / CSS
Allsole美国/加拿大:英国一家专门出售品牌鞋子的网站
2018/10/21 全球购物
阿迪达斯英国官方网站:adidas英国
2019/08/13 全球购物
Bath & Body Works阿联酋:在线购买沐浴和身体用品
2021/02/27 全球购物
什么是Assembly(程序集)
2014/09/14 面试题
工程负责人任命书
2014/06/06 职场文书
第一书记观后感
2015/06/08 职场文书
2016年习总书记讲话学习心得体会
2016/01/20 职场文书
三十年再续同学情倡议书
2019/11/27 职场文书
看看如何用Python绘制小米新版天价logo
2021/04/20 Python