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

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

為什么第一行是 A --> B?

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

正在回答

3 回答

def move(n, a, b, c):
??? if n ==1:????????????????????//當n 等于1時才執行,所以這個判斷語句執行否,也就是后面的句子
??????? print a, '-->', c
??????? return
??? move(n-1, a, c, b)????//這里就是if后的句子,再執行move函數,但是n-1,也就是再判斷一次n是否等于1,不行就一直重復執行,知道n=1,而這里的b和c的位置互換了,當執行if 里的輸出時,實際輸出的是c那個位置的b
??? print a, '-->', c
??? move(n-1, b, a, c)
move(4, 'A', 'B', 'C')

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

其實很好理解,當n不等于1的時候,move(n-1, a, c, b),這個語句會無限執行。

以n=2為例,當執行語句move(1, a, c, b),會出現程序的一個輸出語句即print a, '-->', c。

print 里的a,c代表的是move(1, 'A', 'C', 'B')里的a和c,這里的a,c代表的是堆棧的物理位置,

對應輸出就是A-->B.

由于n=1,故這部分語句

? ? if n ==1:
??????? print a, '-->', c
??????? return

輸出結束。

執行完成之后繼續執行下列語句

? ? print a, '-->', c

注意,這里是以n=2為輸入,對應還是move(2, A, B, C),故輸出a,c對應就是A-->C.

最后一個語句move(n-1, b, a, c),n=2,這時候對應move(1,'B',?'A',?'C'),再走if語句,

? ? if n ==1:
??????? print a, '-->', c
??????? return

輸出a,c對應就是B-->C。

return結束。

不知道有沒有錯誤的地方。有錯望糾正。

n=2的完整輸出:

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




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

后面的還是看不懂!大神,完善一下


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

舉報

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

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

進入課程

為什么第一行是 A --> B?

我要回答 關注問題
微信客服

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

幫助反饋 APP下載

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

公眾號

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