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

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

計算n的階乘可以使用以下代碼,沒有循環怎么實現階乘的呢?

http://img1.sycdn.imooc.com//5764d70c000197b103700395.jpg

如果n=5,在方法里result = factorial(n-1)*n; 實現的應該是4*5,為什么還會1*2*3*4*5呢???

新手這里面沒有循序,所以想不明白,請大神指點一下?。。。。?/p>

正在回答

3 回答

”當碰到一個條件的時候都會再重復的從頭說起“,理解這句話就行了,程序執行到“result=factorial(n-1)*n時,遇到了factorial(n-1),所以程序要從頭開始執行,此時n=n-1;這就完成了循環

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

go_bacK_love 提問者

非常感謝!
2016-07-10 回復 有任何疑惑可以回復我~

factorial()是個遞歸函數,當執行result = factorial(n-1)*n;時,實現的并不是4*5,因為factorial(n-1)會繼續執行函數factorial()。簡單來說就是函數里面套函數,直到滿足跳出條件(本例中,main函數中n=5,所以它的跳出條件就是n==1),某種意義上也是一種循環吧



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

factorial(5)? result=f(4)*5

f(4)? result=f(3)*4

f(3)? result=f(2)*3

f(2)? result=f(1)*2

f(1)? result=1

然后跳出 往回帶? result=1*2*3*4*5

return result

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

舉報

0/150
提交
取消

計算n的階乘可以使用以下代碼,沒有循環怎么實現階乘的呢?

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

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

幫助反饋 APP下載

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

公眾號

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