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

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

誰能給我講一下這個遞歸函數的計算過程是怎樣的,實在好難理解!??!

遞歸函數原理。。。。

正在回答

2 回答

遞歸就是在函數內部調用函數本身,?

def?fact(n):
????if?n==1:
????????return?1
????return?n?*?fact(n?-?1)

函數fact(n)?在內部調用fact(n - 1),?而調用fact(n - 1)時又會調用fact(n - 2).?

#每次調用都把參數n替換為n - 1(有點類似數學里的整體代換)

當n減到等于1時不再調用本身,?這個就是遞歸函數的出口,?一直到這時候,?遞歸函數才開始計算數值

1 * 2 * 3 * 4 * ......* (n - 1) * n

也就是n!

1 回復 有任何疑惑可以回復我~
a=4;
def?jiecheng(n):
????if?n==2:
????????return?2
????return?n*jiecheng(n-1)
print?jiecheng(a)

#?拿這個階乘函數為例,當a=4遞歸的過程是:
#?4*jiecheng(3)
#?4*(3*jiecheng(2))
#?當n=2時
#?jiecheng(2)返回2
#表達式變為4*(3*2)=4*6=24
#?遞歸函數在沒遇到return?常數之前是沒有實際的計算乘積的


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

舉報

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

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

進入課程

誰能給我講一下這個遞歸函數的計算過程是怎樣的,實在好難理解?。。?/h1> 我要回答 關注問題

微信客服

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

幫助反饋 APP下載

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

公眾號

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