题目描述

对于传统的汉诺塔游戏我们做一个拓展,我们有从大到小放置的n个圆盘,开始时所有圆盘都放在左边的柱子上,按照汉诺塔游戏的要求我们要把所有的圆盘都移到右边的柱子上,请实现一个函数打印最优移动轨迹。

给定一个int n,表示有n个圆盘。请返回一个string数组,其中的元素依次为每次移动的描述。描述格式为: move from [left/mid/right] to [left/mid/right]。

测试样例:
1
返回:move from left to right
思路:递归
代码实现
class Hanoi:
def chkStep(self, arr, n):
# write code here
self.initStatus = [1]*n
self.allStatus = [[1]*n]
self.move(n,1,2,3)
i = 0
for s in self.allStatus:
if s == arr:
return i
i = i+1
return -1
def move(self, n, left, mid, right):
if n <= 0:
return
self.move(n-1, left, right, mid)
self.change(n, right)
self.move(n-1, mid, left, right)
def change(self, n, right):
self.initStatus[n-1] = right
self.allStatus.append(self.initStatus[:])

最新文章

  1. SPSS数据分析—卡方检验
  2. iscroll4框架解析[webapp开发](转)
  3. FTP方式获取文件步骤
  4. 自定义web服务器(四)
  5. div 固定宽高 水平垂直居中方法
  6. return;,return false,return true----------浅析
  7. php框架
  8. spark未来的发展方向
  9. PHP 底层的运行机制与原理 --转
  10. Scheme 中的 pair 和 list 简述
  11. 关于使用Xcode9.0使用[UIImage imageNamed:]返回null的问题
  12. TimesTen中文乱码问题(其实是cmd.exe中文乱码)
  13. 第25月25日 urlsession
  14. C语言 &#183; 8皇后问题
  15. Apache+jboss群集优化
  16. 【POJ】2454.Jersey Politics
  17. mysql插入、更新与删除
  18. Extjs学习笔记--(二)
  19. numpy基础入门
  20. python 生成器 迭代器 yiled

热门文章

  1. Linux下安装docker
  2. d3.event=null
  3. hive中控制文件生产个数
  4. 【转】LVDS基础、原理、图文讲解
  5. 持续集成CI/CD
  6. Asp.Net MVC 从客户端&lt;a href=&quot;http://www....&quot;)中检测到有潜在危险的 Request.Form 值
  7. [GXOI/GZOI2019]与或和
  8. Linux中python3,django,redis以及mariab的安装
  9. robot_framework环境搭建
  10. Headless Service 和Service