亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

不明白???求解

def?move(n,?a,?b,?c):
????if?n==1:
????????print?a,'-->',c
????????return
????move(n-1,a,c,b)
????move(1,a,b,c)
????move(n-1,b,a,c)
????
????????
move(4,?'A',?'B',?'C')

結果:

A --> B
A --> C
B --> C
A --> B
C --> A
C --> B
A --> B
A --> C
B --> C
B --> A
C --> A
B --> C
A --> B
A --> C
B --> C

這個里面的C-->A?? C --> B? 是怎么實現出來的?

正在回答

2 回答

n=4,計算機的計算流程如下

move(3, a, c, b)#這時終點是b,起點為a,相當于將盤子從a移動到b
?? ?move(2, a, b, c)#這時終點是c,起點為a,相當于將盤子從a移動到c
?? ??? ?move(1, a, c, b)?? ?print a -> b
?? ??? ?move(1, a, b, c)?? ?print a -> c
?? ??? ?move(1, b, a, c)?? ?print b -> c

?? ?move(1, a, c, b)?? ??? ?print a -> b

?? ?move(2, c, a, b)#這時終點是b,起點為c,相當于將盤子從c移動到b
?? ??? ?move(1, c, b, a)?? ?print c -> a
?? ??? ?move(1, c, a, b)?? ?print c -> b
?? ??? ?move(1, a, c, b)?? ?print a -> b

move(1, a, b, c)?? ??? ??? ?print a -> c

move(3, b, a, c)#這時終點是c,起點為b,相當于將盤子從b移動到c
?? ?move(2, b, c, a)#這時終點是a,起點為b,相當于將盤子從b移動到a
?? ??? ?move(1, b, a, c)?? ?print b -> c
?? ??? ?move(1, b, c, a)?? ?print b -> a
?? ??? ?move(1, c, b, a)?? ?print c -> a

?? ?move(1, b, a, c)?? ??? ?print b -> c

?? ?move(2, a, b, c)#這時終點是c,起點為a,相當于將盤子從a移動到c
?? ??? ?move(1, a, c, b)?? ?print a -> b
?? ??? ?move(1, a, b, c)?? ?print a -> c
?? ??? ?move(1, b, a, c)?? ?print b -> c

3 回復 有任何疑惑可以回復我~
#1

whoask

十分感謝!??!看了這么多答案,就你的最簡單直接!
2017-02-13 回復 有任何疑惑可以回復我~

這篇文字,或許對你理解有幫助:http://www.45fan.com/a/question/56773.html

關鍵是理解遞歸的思路,直接閱讀代碼,的確是難以理解。

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

MH__Linux 提問者

思想我知道,我就是想知道代碼是如何實現這個過程的
2016-10-27 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消
初識Python
  • 參與學習       758390    人
  • 解答問題       8967    個

學python入門視頻教程,讓你快速入門并能編寫簡單的Python程序

進入課程

不明白?。壳蠼?/h1> 我要回答 關注問題

微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號