为了账号安全,请及时绑定邮箱和手机立即绑定

是我理解错了吗?

def move(n, a, b, c): 
   if n==1:        
   print a,'-->',c        
   return    
   move(n-1,a,c,b)    
   print a,'-->',b    
   move(1,a,b,c)    
   print a,'-->',c    
   move(n-1,b,a,c)    
   print b,'-->',c


正在回答

1 回答

这么理解吧
def hanoi(n, a, b, c):    
if n == 1:        
print(a, '-->', c)   //   
else:        
hanoi(n - 1, a, c, b)    //将n-1个盘子由a移动到b,以c为辅助柱子(注意参数顺序)    
print(a, '-->', c)       //将a上的最后一个盘子移动到c
hanoi(n - 1, b, a, c)    //将n-1个盘子由b移动到c,以a为辅助柱子
可以上百度一下汉诺塔原理,你写成这样应该没有把递归算法理解进去


0 回复 有任何疑惑可以回复我~
#1

Sylph_Jade 提问者

我以为print这个语句没有用的。。。
2019-07-02 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
初识Python
  • 参与学习       758625    人
  • 解答问题       8667    个

学python入门视频教程,让你快速入门并能编写简单的Python程序

进入课程

是我理解错了吗?

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信