|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
def hanota(n,x='x',y='y',z='z'):
if n == 1:
print(x,'--->',z)
else:
hanota(n-1,x,z,y)#将前n-1个盘子从x移到y上
print(x,'-->',z)#将底下的最后一个盘子从x移到z
hanota(n-1,y,x,z)#将y的n-1个盘子移到z上
hanota(3)
这些递归def hanota(3,x='x',y='y',z='z'): 中x,y,z都只是形参,进入递归时 hanota(2,x,z,y),此时实参n=n-1=2,x=x, y=z, z=y的!!!不等于1,进入else,分成3枝(分支1:hannota(2,x,z,y),分支2:print(x,'-->',z),
分支3:hanota(2,y,x,z))
分枝1先运行即:hanota(2,x,z,y),递归不等于1,又分成3枝(1子枝1:hanota(1,x,y,z),
1子枝2:print(x,'-->',y); 1子枝3:hanota(1,z,x,y))
1子枝1先运行:1==1;第一次打印print(x,'-->',z)
1子枝2运行:print(x,'-->',y),第二次打印print(x,'-->',y)
1子枝3运行:hanota(1,z,x,y),1==1,第三次打印print(z,'-->',y)
看了一篇文章还是没懂,递归hanota(2,x,z,y)的时候为什么hanota(1,x,y,z) 怎么变成了x,y,z 1子支变为了hanota(1,z,x,y) 同理 请大佬指教,看懵了
|
|