1、您好很高興回答您的問題。首先main函數(shù)需要一個返回值給操作系統(tǒng)以讓操作系統(tǒng)判斷函數(shù)是否成功,所以您的程序最后應(yīng)該加上return 0;這樣程序就可以正確的運行了。另外在printf里面可以加上一個換行符/n,這樣輸出會好看一點。
創(chuàng)新互聯(lián)建站專業(yè)為企業(yè)提供黃石網(wǎng)站建設(shè)、黃石做網(wǎng)站、黃石網(wǎng)站設(shè)計、黃石網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、黃石企業(yè)網(wǎng)站模板建站服務(wù),10年黃石做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。
2、printf(%f\n,t); // 打印t做什么,應(yīng)該是c。
3、用一臨時變量t記錄第n項的值,則第n+1項的值就是t(2(n+1)-1)=t(2n+1)。根據(jù)這一思路編程,既可以簡化代碼,又可以提高執(zhí)行時效(將求1~2n-1的奇數(shù)積過程減縮為求一次乘法)。
4、可以使用循環(huán)或遞歸來計算數(shù)列的前n項和。在這個例子中,數(shù)列的通項公式為an = (-1)^(n+1) / (2^n * (n-1))。因此,要計算前n項和,可以使用循環(huán)來迭代計算每一項,并將它們相加。
x有四個取值,所以定義一個求y(x)的函數(shù)是較好選擇。
s=s+t; //s是總和,t是每一項的值。t=1; //每建立一項之前t要初始化。j=0; //通過j建立循環(huán)控制每一項的數(shù)字個數(shù),也就是循環(huán)次數(shù)。while(j=i){ t=t*f; //通過循環(huán)逐步確定t的值。
你前面寫的那個式子就有問題,怎么又7+8+9了?從程序來看,最里面的循環(huán)是求每一個加數(shù),例如N為5,那么就有5個加數(shù),分5次循環(huán)求得這5個加數(shù)。
能計算的話可以通過那個編程師的負(fù)八次方的一個笑,然后得出最終的結(jié)果了,然后呢點擊呃選中就可以了。
Fibonacci(int n){ if(n == 1 || n == 2)// 遞歸結(jié)束的條件,求前兩項 return 1;else return Fibonacci(n-1)+Fibonacci(n-2);// 如果是求其它項,先要求出它前面兩項,然后做和。
奉勸大家,若樓主不給錢就不要幫他做,理由有二:這是個很初級的東西,做出來也體現(xiàn)不出什么水平。
遞歸有一個堆棧的概念,那就意味著他是一個反理解的過程:就象數(shù)學(xué)遞推一樣,你知道第一項,第二項,又知道通項公式,那你就可以知道任何一項。然后你看代碼:fun(0)==0,fun(1)==1;是告訴你一二項。
斐波那契數(shù)列為:0,1,1,2,3,5,8,1../*你的程序*/ includestdio.h int fib(int n,int f){ if(n==1&&n==2) /*n不可能同時等于1和2,所以遞歸無終點,會一直遞歸下去。
include int fibonacci(int n){ if(n == 1 || n == 2)// 遞歸結(jié)束的條件,求前兩項 return 1;else return fibonacci(n-1)+fibonacci(n-2);// 如果是求其它項,先要求出它前面兩項,然后做和。
從上面的這個邏輯,你會發(fā)現(xiàn),如果是遞歸調(diào)用,會有大量的入棧操作。這個東西是浪費時間的。并且,如果調(diào)用次數(shù)過多,會造成棧空間迅速用完,導(dǎo)致程序失敗。這樣,又會逼迫你加大??臻g。