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

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

這答案不對嗎

def move(n, a, b, c):

? ? if n==1:

? ? ? ? print ('A-->C')

? ? ? ? move(n-1, a, b, c)

? ? elif n>1:

? ? ? ? print ("A-->B")

? ? ? ? move(n-1, a, b, c)

? ? ? ? print ("B-->C")

? ? ? ? ? ?

move(4, 'A', 'B', 'C')


正在回答

2 回答

當n==1的時候,你的遞歸已經到了最后一個數了,你再move(n-1)就是move(0)了。你這個代碼會無限執行下去

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

慕哥5869767

當n == 1的時候就返回了 不再繼續
2020-01-04 回復 有任何疑惑可以回復我~

漢諾塔 (http://baike.baidu.com/view/191666.htm) 的移動也可以看做是遞歸函數。

我們對柱子編號為a, b, c,將所有圓盤從a移到c可以描述為:

如果a只有一個圓盤,可以直接移動到c;

如果a有N個圓盤,可以看成a有1個圓盤(底盤) + (N-1)個圓盤,首先需要把 (N-1) 個圓盤移動到 b,然后,將 a的最后一個圓盤移動到c,再將b的(N-1)個圓盤移動到c。

請編寫一個函數,給定輸入 n, a, b, c,打印出移動的步驟:

move(n, a, b, c)


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

舉報

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

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

進入課程

這答案不對嗎

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

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

幫助反饋 APP下載

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

公眾號

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