91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

c語言遞歸函數的使用方法

發布時間:2020-06-11 09:39:53 來源:億速云 閱讀:216 作者:Leah 欄目:編程語言

這篇文章給大家分享的是c語言遞歸函數的使用方法。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。

遞歸就是一個過程或 函數 在其定義或說明中有直接或間接調用自身的一種方法;遞歸函數就是直接或間接調用自身的函數,也就是自身調用自己的過程。

1.Fibonacci數

我們直到Fibonacci數的遞推公式為:F(0)=F(1)=1,F(n)=F(n-1)+F(n-2) n>=2;

這個明顯地給出了遞歸邊界n=0或1的時候F(n)的值,和遞歸邏輯F(n)=F(n-1)+F(n-2),即遞推公式.所以這個遞歸函數不難書寫

#includeusing namespace std;
int F(int n)//函數返回一個數對應的Fibonacci數{ if(n0 || n1)//遞歸邊界
return 1; return F(n-1) + F(n-2);//遞歸公式}
int main(){ //測試
int n; while(cin >> n) cout << F(n) << endl;
return 0;
}

2.階乘的遞歸公式:n*F(n-1)

代碼如下:

#includeusing namespace std;
int F(int n){ if(n==0)//遞歸邊界
return 1;
return n*F(n-1);//遞歸公式}
int main(){ int n; cin >> n; cout << F(n) << endl;
return 0;
}

3.數組求和

給一個數組a[]:a[0],a[1],…,a[n-1]如何用遞歸的方式求和?

仍然是兩個問題:遞歸邊界和遞歸公式.

遞歸邊界是什么?一時不容易想到,但是我們想到了求和,多個數的求和過程是什么,x,y,z,w手動求和的過程是什么?步驟如下:

x+y=a,任務變為a,z,w求和

a+z=b,任務變為b,w求和

b+w=c得出答案

思考一下,【得出答案】這一步為什么就可以得出答案呢?(廢話?)是因為,一個數不用相加就能得出答案.

所以,遞歸的邊界就是只有一個數.

所以,遞歸邊界有了,那么遞歸公式呢?其實手動計算過程中,隱含了遞歸公式:

其中+為求兩個數的和,F為求多個數的和的遞歸函數.代碼如下:

#includeusing namespace std;
int F(int a[],int start,int end){ if(start==end)//遞歸邊界
return a[start];
return a[start] + F(a,start+1,end);//遞歸公式}
int main(){ int a[] = {1,2,3,4,5}; int s=0,e=4; cout << F(a,s,e) << endl;
return 0;
}

4.求數組元素最大值

手動求最大值的過程是什么,遍歷+比較,過程如下:

例如,求3,2,6,7,2,4的最大值:先設置最大值max=-999999,然后將max和數組元素逐個(遍歷)比較如果a[i]>max,則更新max的值為a[i],否則max不變,繼續向后遍歷,直到遍歷結束.

max<3,則max=3

max>2,max=3不變

max<6,則max=6

max<7,則max=7

max>2,max=7不變

max>4,max=7不變

遍歷結束,max=7為最大值.

和求和類似,遞歸的公式如下:

其中max為求兩個數的較大值函數,F為求多個數的最大值的遞歸函數.代碼如下:

#includeusing namespace std;
#define max(a,b) (a>b?a:b)
int F(int a[],int s,int e){ if(s==e) return a[s]; else if(s+1 == e)//遞歸邊界
return max(a[s],a[e]);
return max(a[s],F(a,s+1,e));//遞歸公式!!!}
int main(){ int a[] = {5,1,4,6,2}; int s = 0,e = 4; cout << F(a,s,e) << endl;
return 0;
}

以上就是c語言遞歸函數的使用方法介紹,詳細使用情況還得要大家自己使用過才能知道具體要領。如果想閱讀更多相關內容的文章,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新宾| 塔城市| 开平市| 高淳县| 天长市| 青浦区| 崇仁县| 中牟县| 手游| 保靖县| 元江| 柳江县| 湟源县| 宝清县| 天门市| 遵化市| 阿拉善右旗| 锡林郭勒盟| 镇巴县| 达尔| 东乌| 疏勒县| 应用必备| 晋中市| 东丰县| 上饶县| 宜春市| 枝江市| 平湖市| 郑州市| 兴安盟| 宜兰县| 宾阳县| 衡水市| 乐业县| 宁安市| 贵州省| 林甸县| 稻城县| 临汾市| 内乡县|