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

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

具體的輸出步驟是怎么來的

這個程序大概看懂了,每一步知道什么意思,但是這個輸出結果沒看懂,那個A-->B,C-->A,C-->B是怎么來的,有大佬詳細分析一下每一步運行得出的結果嗎

正在回答

4 回答

兄弟,講解步驟還是比較麻煩的,每n層,就需要有2^n-1次步驟,4層就有15步

所以簡單講解一下3和2層,然后自己驗證4層的移動,驗證move(4,a,b,c)的第一步驟move(3,a,c,b)下面的7個步驟就可以。

2層:

move (2,a,b,c)

? ?#都會先判斷是否為1

? ?#然后不是,就會進行接下來三步: 1:move(n-1, a, c, b),2: print a, '-->', c,3:move(n-1, b, a, c)

? ?1:move(1,a,c,b)#分析此處的內部運作

? ? ? ?#因為是1,所以不走三步,直接執行if下print a-c,但是這里可能就導致不好理解了

? ? ? ?#其實這里是指print 1位到3位,可見在 move(1,a,c,b)中,1位是a,3位是b

? ? ? ?#打印結果是A--》B

? ?2:print a-c #其實也是執行print本層move的 1位到3位 ?

? ? ? ? #在本層的move (2,a,b,c)中,1位是a,3位是c

? ? ? ?#打印結果是A--》C

? 3:move(1,b,a,c)

? ? ? ?#因為是1,所以執行print a-c---》print 1位到3位,1位是b,3位是c

? ? ? ?#打印結果是B--》C

? ? ? ?#后面不在重復打印的是本層move的1位到3位

? ? ? ?AB ?AC ? BC

3層:

?move(3,a,b,c)

? ? #判斷不是1

? ? #進入接下來三步

? ? 1:move(2,a,c,b)

? ? ? ? #這里的abc位置剛才沒講,因為剛才和程序的變化一樣

? ? ? ? #這里因為有多層,講解一下:

? ? ? ? #1步驟:move(n-1, a, c, b)程序的意思是,上層的move里的第二位和第三位互換

? ? ? ? #3步驟:move(n-1, b, a, c)程序的意思是,上層move里的第一位和第二位互換

? ? ? ? #這里2不是1,所以要進行三步

? ? ? ? ①:move(1,a,b,c)#上層move的2,3位互換

? ? ? ? ? ? ????????#打印結果是A--》C

? ? ? ? ②:打印結果是A--》B

? ? ? ? ③:move(1,c,a,b)#上層move的1,2位互換

? ? ? ? ? ????????? #打印結果是C--》B

? ? ?2:打印結果是A--》C#提示一下,本層是:move(3,a,b,c)

? ? ?3:move(2,b,a,c)#上層move的1,2位互換

? ? ? ? ?①:move(1,b,c,a)#上層move的2,3位互換

? ? ? ? ? ? ?????????#打印結果是B--》A

? ? ? ? ?②:打印結果是B--》C

? ? ? ? ?③:move(1,a,b,c)#上層move的1,2位互換

? ? ? ? ? ? ?????????#打印結果是A--》C ?

AC ? AB ? CB ? AC ? BA ? BC ? AC?

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

kuduo 提問者

謝大佬??!我再看看
2019-04-19 回復 有任何疑惑可以回復我~
#2

weixin_慕工程4589350

看完你的講解感覺更亂了
2019-04-20 回復 有任何疑惑可以回復我~
#3

慕圣4301918 回復 weixin_慕工程4589350

def move(n, a, b, c): if n==1: print a,'-->',c return print a,b,c,n,'------\n' move(n-1,a,c,b) print a,b,c,n,'++++++' print a,'-->',c print a,b,c,n,',,,,,,,' move(n-1,b,a,c) print a,b,c,n+3,'1111111111111\n' move(4, 'A', 'B', 'C') 用這個打印一下,就能明白其中的嵌套了
2019-04-23 回復 有任何疑惑可以回復我~

print

print?da


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

把我看暈了,繞進去了,出不來了,貌似好復雜的樣子

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

第一個 move(n-1,a,c,b) 表示的是把上面的n-1塊圓盤從 a移動到b然后 再把 a 移動到 c? 即 print a--->c第二個move(n-1,b,a,c) 表示把放在b上的n-1個圓盤移動到c上,實現了整個程序而這個 move(4, 'A', 'B', 'C') 表示的是調用這個函數,把參數給傳遞進去。...

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

舉報

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

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

進入課程

具體的輸出步驟是怎么來的

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

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

幫助反饋 APP下載

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

公眾號

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