网站首页
网站导航
Ctrl+D收藏
首 页
代码段
源码包
文档库
工具箱
代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
Python
】
递归版汉诺塔
作者:
houlu
/ 发布于
2014/4/8
/
667
from time import sleep def disp_sym(num, sym): print(sym*num, end='') #recusion def hanoi(a, b, c, n, tray_num): if n == 1: move_tray(a, c) disp(tray_num) sleep(0.7) else: hanoi(a, c, b, n-1, tray_num) move_tray(a, c) disp(tray_num) sleep(0.7) hanoi(b, a, c, n-1, tray_num) def move_tray(a, b): for i in a: if i != 0: for j in b: if j != 0: b[b.index(j) - 1] = i a[a.index(i)] = 0 return b.append(i) b.pop(0) a[a.index(i)] = 0 return def disp(tray_num): global a, b, c for i in range(tray_num): for j in ['a', 'b', 'c']: disp_sym(5, ' ') eval('disp_sym(tray_num - ' + j + "[i], ' ')") eval('disp_sym(' + j + "[i], '=')") disp_sym(1, '|') eval('disp_sym(' + j + "[i], '=')") eval('disp_sym(tray_num - ' + j + "[i], ' ')") print() print('---------------------------------------------------------------------------') tray_num=int(input("Please input the number of trays:")) tray=[] for i in range(tray_num): tray.append(i + 1) a=[0]*tray_num b=a[:] c=a[:] a = tray[:] disp(tray_num) hanoi(a, b, c, tray_num, tray_num)
评论列表
本站所提供的代码,版权归原作者所有,若有侵犯作者版权,请与我们联系,我们将立即删除或修改。谢谢!
本站所有代码发布及提供者。
试试其它关键字
汉诺塔
同语言下
.
比较两个图片的相似度
.
过urllib2获取带有中文参数的url内容
.
不下载获取远程图片的宽度和高度及文件大小
.
通过qrcode库生成二维码
.
通过httplib发送GET和POST请求
.
Django下解决小文件下载
.
遍历windows的所有窗口并输出窗口标题
.
根据窗口标题调用窗口
.
python 抓取搜狗指定公众号
.
pandas读取指定列
可能有用的
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
.
实现对图片上传的接收
.
判断用户输入的是否为IP地址
houlu
贡献的其它代码
(
3
)
.
递归版汉诺塔
.
根据容器长度自动截断字符串并添加...
.
简单的猜数字游戏
地图
本站
我们
服务
版权
联系
回馈
博客