日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

递归算法及经典递归例子代码实现

發布時間:2023/12/10 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 递归算法及经典递归例子代码实现 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?????????????????????????????

遞歸(recursion):程序調用自身的編程技巧。

? 遞歸滿足2個條件:

??? 1)有反復執行的過程(調用自身)

??? 2)有跳出反復執行過程的條件(遞歸出口)

?

遞歸例子:

(1)階乘

???????? n! = n * (n-1) * (n-2) * ...* 1(n>0)

//階乘 int recursive(int i) {int sum = 0;if (0 == i)return (1);elsesum = i * recursive(i-1);return sum; }

(2)河內塔問題

//河內塔 void hanoi(int n,int p1,int p2,int p3) {if(1==n)cout<<"盤子從"<<p1<<"移到"<<p3<<endl;else{hanoi(n-1,p1,p3,p2);cout<<"盤子從"<<p1<<"移到"<<p3<<endl;hanoi(n-1,p2,p1,p3);} }

3)全排列

? 從n個不同元素中任取mm≤n)個元素,按照一定的順序排列起來,叫做從n個不同元素中取出m個元素的一個排列。當m=n時所有的排列情況叫全排列。

? 如1,2,3三個元素的全排列為:

? 1,2,3

? 1,3,2

? 2,1,3

? 2,3,1

? 3,1,2

? 3,2,1

//全排列 inline void Swap(int &a,int &b) {int temp=a;a=b;b=temp; } void Perm(int list[],int k,int m) {if (k == m-1) {for(int i=0;i<m;i++){printf("%d",list[i]);}printf("n");}else{for(int i=k;i<m;i++){Swap(list[k],list[i]); Perm(list,k+1,m);Swap(list[k],list[i]); }} } (4)斐波那契數列

? 斐波納契數列,又稱黃金分割數列,指的是這樣一個數列:1123581321、……

? 這個數列從第三項開始,每一項都等于前兩項之和。

? 有趣的兔子問題:

?

? 一般而言,兔子在出生兩個月后,就有繁殖能力,一對兔子每個月能生出一對小兔子來。如果所有兔子都不死,那么一年以后可以繁殖多少對兔子?

? 分析如下:

? 第一個月小兔子沒有繁殖能力,所以還是一對;

? 兩個月后,生下一對小兔子,總數共有兩對;

? 三個月以后,老兔子又生下一對,因為小兔子還沒有繁殖能力,總數共是三對;

? …… 

? 依次類推可以列出下表:

//斐波那契 long Fib(int n) {if (n == 0) return 0;if (n == 1) return 1;if (n > 1) return Fib(n-1) + Fib(n-2); }

?

總結

以上是生活随笔為你收集整理的递归算法及经典递归例子代码实现的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。