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之玩转字符串(2)更新篇
Sep 28 Python
Python for Informatics 第11章之正则表达式(四)
Apr 21 Python
对Python 数组的切片操作详解
Jul 02 Python
Django单元测试工具test client使用详解
Aug 02 Python
Python生成个性签名图片获取GUI过程解析
Dec 16 Python
Python基于codecs模块实现文件读写案例解析
May 11 Python
解决导入django_filters不成功问题No module named 'django_filter'
Jul 15 Python
搭建pypi私有仓库实现过程详解
Nov 25 Python
pyspark对Mysql数据库进行读写的实现
Dec 30 Python
通用的Django注册功能模块实现方法
Feb 05 Python
使用Python爬取小姐姐图片(beautifulsoup法)
Feb 11 Python
利用python实时刷新基金估值(摸鱼小工具)
Sep 15 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采集相关教程之一 CURL函数库
2010/02/15 PHP
thinkPHP2.1自定义标签库的导入方法详解
2016/07/20 PHP
js Flash插入函数免激活代码
2009/03/31 Javascript
基于JavaScript如何实现ajax调用后台定义的方法
2015/12/29 Javascript
基于javascript实现泡泡大冒险网页版小游戏
2016/03/23 Javascript
Js类的静态方法与实例方法区分及jQuery拓展的两种方法
2016/06/03 Javascript
Web安全测试之XSS实例讲解
2016/08/15 Javascript
JS定时器实现数值从0到10来回变化
2016/12/09 Javascript
js实现将json数组显示前台table中
2017/01/10 Javascript
详解如何使用vue-cli脚手架搭建Vue.js项目
2017/05/19 Javascript
JS身份证信息验证正则表达式
2017/06/12 Javascript
vue之浏览器存储方法封装实例
2018/03/15 Javascript
深入理解js 中async 函数的含义和用法
2018/05/13 Javascript
vue实现重置表单信息为空的方法
2018/09/29 Javascript
详解微信小程序实现跑马灯效果(附完整代码)
2019/04/29 Javascript
在Echarts图中给坐标轴加一个标识线markLine
2020/07/20 Javascript
[56:38]DOTA2-DPC中国联赛正赛Aster vs Magma BO3 第一场 3月5日
2021/03/11 DOTA
python自动发送邮件脚本
2018/06/20 Python
Tensorflow中的placeholder和feed_dict的使用
2018/07/09 Python
详解Python网络框架Django和Scrapy安装指南
2019/04/01 Python
Python Django给admin添加Action的方法实例详解
2019/04/29 Python
python 3.6.7实现端口扫描器
2019/09/04 Python
Django操作session 的方法
2020/03/09 Python
python 如何把docker-compose.yaml导入到数据库相关条目里
2021/01/15 Python
利用HTML5中Geolocation获取地理位置调用Google Map API在Google Map上定位
2013/01/23 HTML / CSS
HTML5 图片预加载的示例代码
2020/03/25 HTML / CSS
幼儿园春游活动方案
2014/01/19 职场文书
30岁生日感言
2014/01/25 职场文书
《太阳》教学反思
2014/02/21 职场文书
售房协议书
2014/08/19 职场文书
党员对照检查材料思想汇报
2014/09/16 职场文书
股东出资证明书范例
2014/10/04 职场文书
领导欢迎词范文
2015/01/26 职场文书
大学生学期个人总结
2015/02/12 职场文书
领导欢送会主持词
2015/07/06 职场文书
Go语言实现Snowflake雪花算法
2021/06/08 Golang