這篇文章主要介紹了C語(yǔ)言如何實(shí)現(xiàn)斐波那契數(shù)列的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇C語(yǔ)言如何實(shí)現(xiàn)斐波那契數(shù)列文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。
成都創(chuàng)新互聯(lián)公司為客戶提供專業(yè)的成都網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、外貿(mào)網(wǎng)站建設(shè)、程序、域名、空間一條龍服務(wù),提供基于WEB的系統(tǒng)開(kāi)發(fā). 服務(wù)項(xiàng)目涵蓋了網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站程序開(kāi)發(fā)、WEB系統(tǒng)開(kāi)發(fā)、微信二次開(kāi)發(fā)、移動(dòng)網(wǎng)站建設(shè)等網(wǎng)站方面業(yè)務(wù)。
C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)遞歸之斐波那契數(shù)列
首先,關(guān)于遞歸深度,遞歸提供了一個(gè)簡(jiǎn)單的定義。如果調(diào)用Fibonacci(),當(dāng)n為1或2時(shí)Fibonacci(n)應(yīng)返回1;對(duì)于其他數(shù)值應(yīng)返回Fibonacci(n-1)+Fibonacci(n-2);
long Fibonacci(n) { if (n > 2) return Fibonacci(n-1)+Fibonacci(n-2); else return 1; }
然后是兔子總數(shù)問(wèn)題。
有一對(duì)兔子,從出生后第三個(gè)月起每個(gè)月都生一對(duì)兔子,小兔子長(zhǎng)到第三個(gè)月后又生一對(duì)兔子,假如兔子都不死,每個(gè)月兔子對(duì)數(shù)為多少?
思考這道題的時(shí)候,如果你簡(jiǎn)單的推算一下,會(huì)發(fā)現(xiàn)兔子每個(gè)月的對(duì)數(shù)就是斐波那契數(shù)列。
第一個(gè)月:1對(duì);
第二個(gè)月:1對(duì);
第三個(gè)月:2對(duì);
第四個(gè)月:3對(duì):
第五個(gè)月:5對(duì):
第六個(gè)月:8對(duì);
……
我之前做這道題的時(shí)候,覺(jué)得思路很簡(jiǎn)單,就是從第三個(gè)月起,求每個(gè)月的兔子數(shù)時(shí),只要把這個(gè)月的前兩個(gè)月總數(shù)相加。
這是我之前的代碼,用f1和f2表示月。:
#includeint main() { int f1,f2; int month,ct; printf("請(qǐng)輸入月份:"); scanf("%d",&month); if(month<=2) printf("兩只。\n"); if (month > 2) { f1 = f2 = 1; ct = 0; while(ct < month -2){ f1 = f1+f2; ct += 1; f2 = f1+f2; ct += 1; } if (month %2 == 0){ printf("第 %d 個(gè)月的兔子對(duì)數(shù)為:%d.\n",month,f2); } if (month %2 == 1){ printf("第 %d 個(gè)月的兔子對(duì)數(shù)為:%d.\n",month,f1); } } return 0; }
其實(shí)這個(gè)代碼離遞歸就差一步,很接近了。但是我當(dāng)時(shí)完全沒(méi)有想到。
這是我重新修改之后的代碼:
#includelong Fibonacci(n) { if (n > 2) return Fibonacci(n-1)+Fibonacci(n-2); else return 1; } int main() { long num; int month; printf("請(qǐng)輸入月份:"); scanf("%d",&month); num = Fibonacci(month); printf("這個(gè)月的兔子對(duì)數(shù)為%d.\n",num); return 0; }
關(guān)于“C語(yǔ)言如何實(shí)現(xiàn)斐波那契數(shù)列”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“C語(yǔ)言如何實(shí)現(xiàn)斐波那契數(shù)列”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。