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

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

遞歸函數,難死我了...我思維轉的慢,求傻瓜式的講解!

#include <stdio.h>

/* 定義獲取單詞數量的函數 */

int getWordNumber(int n)

{? ?

? ? if(n == 1)

? ? {

? ? ? ? return 1;? ? //第一天只會1個單詞

? ? }

? ? else{

? ? ? ? return getWordNumber(n-1)+n;? ? ? ?//到第天會的單詞數量

? ? }

}

int main()

{

? ? int num = getWordNumber(10);? ? ?//獲取會了的單詞數量

? ? printf("小明第10天記了:%d個單詞。\n", num);

? ? return 0;

}

首先我不理解為什么最終的結果不是19,而是55,你看嘛(10-1)+10=19

其次,他是從那一步開始循環的,且循環的過程,及計算過程是怎么樣的?

目前就卡在這

正在回答

4 回答

你那樣子算就不是遞歸了,遞歸就是反復調用自己

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

我跟你有一樣的困惑

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

這個答案也不是55額

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

這是我的猜想

因為 n = 10 所以 執行 else 語塊,所以再次執行 wing函數 ,又因為wing(10-1=9)+10 = 19,所以再次執行 wing函數的時候 n的初始值

是9,9不等于1,再次執行 else語塊,此時 wing(n-1)+n ==? wing(9-1=8)+19=27? ,所以再次執行 wing函數,而此時的初始值是8 ,繼續執行

else 語塊,此時 wing(n-1)+n == wing(8-1)+ 27······依次循環直到 n==1

······························································不知道對不對,請點評

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

舉報

0/150
提交
取消
C語言入門
  • 參與學習       926904    人
  • 解答問題       21532    個

C語言入門視頻教程,帶你進入編程世界的必修課-C語言

進入課程

遞歸函數,難死我了...我思維轉的慢,求傻瓜式的講解!

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

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

幫助反饋 APP下載

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

公眾號

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