作者tasukuchiyan (Tasuku)
看板Python
標題[問題] 重複帶入函式
時間Mon Oct 19 15:12:43 2015
我看了一本書上的一個演算法後,照方法用python寫時發現一個問題,不知道出在哪,
我將它簡化成以下的問題:
def test(a):
if a>0:
a-=1
print(a,'\n','-')
test(a)
else: pass
print(a)
輸入一個數字,當數字大於零時減一,然後重複帶入原函式,直到零。
執行帶入3:
test(3)
結果:
2
-
1
-
0
-
0
0
1
2
跑到0時,應該要停止了,可是他繼續跑,結果最後答案是2
如果將重複帶入的方式改成while的話就沒問題:
def test2(a):
while a>0:
a-=1
print(a,'\n','-')
print(a)
一樣帶入3執行:
test2(3)
結果:
2
-
1
-
0
-
0
最後答案是0,沒問題。
想問重複帶入函式的這方法問題出在哪,謝謝。
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 218.174.23.187
※ 文章網址: https://www.ptt.cc/bbs/Python/M.1445238765.A.6F7.html
→ mikapauli: 你寫了2個print,a>0時會print(a-1)兩次阿 10/19 16:12
推 tiefblau: 呼叫完含式 會回去下一行繼續跑啊 你查一下遞迴怎麼用吧 10/19 16:16
→ alibuda174: 把else: pass改成else: print(a),刪掉底下的print(a) 10/19 17:16
推 Yshuan: 原PO充分證明了遞迴是stack的應用(?) 10/19 22:00
→ tasukuchiyan: 感謝樓上幾位,仔細研究後已經解決問題了 10/20 15:51