汉诺塔I
2024-08-30 19:47:00
题目描述
对于传统的汉诺塔游戏我们做一个拓展,我们有从大到小放置的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[:])
最新文章
- SPSS数据分析—卡方检验
- iscroll4框架解析[webapp开发](转)
- FTP方式获取文件步骤
- 自定义web服务器(四)
- div 固定宽高 水平垂直居中方法
- return;,return false,return true----------浅析
- php框架
- spark未来的发展方向
- PHP 底层的运行机制与原理 --转
- Scheme 中的 pair 和 list 简述
- 关于使用Xcode9.0使用[UIImage imageNamed:]返回null的问题
- TimesTen中文乱码问题(其实是cmd.exe中文乱码)
- 第25月25日 urlsession
- C语言 &#183; 8皇后问题
- Apache+jboss群集优化
- 【POJ】2454.Jersey Politics
- mysql插入、更新与删除
- Extjs学习笔记--(二)
- numpy基础入门
- python 生成器 迭代器 yiled
热门文章
- Linux下安装docker
- d3.event=null
- hive中控制文件生产个数
- 【转】LVDS基础、原理、图文讲解
- 持续集成CI/CD
- Asp.Net MVC 从客户端<;a href=";http://www....";)中检测到有潜在危险的 Request.Form 值
- [GXOI/GZOI2019]与或和
- Linux中python3,django,redis以及mariab的安装
- robot_framework环境搭建
- Headless Service 和Service