遞歸--例子與簡單分析

遞歸(英語:Recursion),又譯為遞回,在數(shù)學(xué)與計算機科學(xué)中,是指在函數(shù)的定義中使用函數(shù)自身的方法。遞歸一詞還較常用于描述以自相似方法重復(fù)事物的過程
------------------維基百科

我記得大學(xué)計算機結(jié)構(gòu)與算法的一節(jié)課上,老師給我們講解了遞歸的整個調(diào)用過程,印象還挺深刻的,因為老師說,,。遞歸,就是有遞有歸,有個問題,我們解決不了,但是我們可以不斷的將問題簡化成相同問題的子問題,直到子化成我們可以解決的問題,返回一個解決方法,然后這個解決方法可以解決更大的問題并返回一個解決方法,如此反復(fù),大問題就解決了,其實遞歸是一種解決問題的手段,而這種思想就是分治思想,對工作中生活中解決問題非常有幫助。

遞歸一般都有一個遞歸函數(shù),這個函數(shù)直接調(diào)用自己或者通過一系列的調(diào)用語句間接的調(diào)用自己,
而函數(shù)里邊一般都會有兩部分,

  • 遞歸結(jié)束條件的語句,邊界條件;
  • 遞歸調(diào)用自己的語句,簡化問題。

如果不理解遞歸,那這個模版也可以套用吧。不過分治的思想真的很重要,需要掌握。

接下來可以分析一些實際的問題來幫助我們更加理解,先從hello world式的N的階乘開始

  • 計算n!的階乘,原始的計算機自然一下子當(dāng)然難以計算,但是我們只要計算出(n-1)!了,n!就能通過(n-1)*n計算出來了呀。那結(jié)束條件是n=1的時候,我們讓1!=1,這樣,當(dāng)n不斷遞減,到1的時候,我們就能得到結(jié)果了
//計算n!
//構(gòu)造一個遞歸函數(shù),兩個部分:
//n=1 的時候,返回1,因為1的階乘就等于1;
//n!=1 的時候,繼續(xù)調(diào)用自己,計算n-1的階乘,并返回n \* (n-1)!;
int recursion(int n) {
    if (n == 1) {
        return 1;
    }
    return recursion(n-1)*n;
}

  • POJ 1664 把M個同樣的蘋果放在N個同樣的盤子里,允許有的盤子空著不放,問共有多少種不同的分法?
    這道題類似整數(shù)劃分問題,整數(shù)劃分使用了一個相加的個數(shù)來輔助遞歸,這種遞歸有兩種情況:
//n>m,有n-m個盤子是空的,這幾個盤子不影響結(jié)果, fun(m,n)=fun(m,m)
//n<m,
//1,至少一個盤空著:f(m,n)=f(m,n-1)
//2,所有盤都放了蘋果:f(m,n)=f(m-n,n)
//結(jié)果= 情況1+情況2..
int fun(int m, int n) {
    if(m==0 || n == 1)
        return 1;
    if(n>m) 
        return fun(m,m);
    else 
        return fun(m,n-1)+fun(m-n,n);
}
  • Hanoi Tower 漢諾塔問題

這個問題應(yīng)該都很熟悉了,有三個桌子a,b,c, 從a移動n個盤子到c,我們不知道怎么移,但是我們可以把移動n-1個盤子當(dāng)作一個整體子問題,然后在這個基礎(chǔ)上做些移動操作然后完成移動n個盤子的操作。

// 問題hanoi(a,b,c,n):
// 三個操作:
// 把n-1個盤子從a移動到b;           hanoi(a,c,b,n-1)
// 把第n個盤子從a移動到c;            move(a,c)
// 把n-1個盤子從b移動到c;           hanoi(b,a,c,n-1)
void hanoi(char a, int b, int c, int n) {
    if(n == 1) 
        printf("\n%c->%c\n"a,c);
    else { 
        hanoi(n-1,a,c,b);
        printf("\n%c->%c\n"a,c);
        hanoi(n-1,b,a,c);
        }
}
  • 斐波拉契數(shù)列求和
//典型的遞歸問題
int Fibonacci(int n){
    if (n <= 1)  
        return n;  
    else  
        return Fibonacci(n-1) + Fibonacci(n-2);  
}
  • 輸入字符串,反轉(zhuǎn)輸出,類似的還有判斷一段字符串回文等
//字符串反轉(zhuǎn)輸出,其實是利用了遞歸的從最里層返回的特性
void recursion() {
    char t;
    cin >> t;
    if (t == '1') {
        return;
    }
    if (t != '1') {
        recursion();
        printf("%c",t);
    }
}

遞歸的簡單分析:遞歸雖然易讀,而且簡單,但是他的運行效率較低,時間,空間復(fù)雜度都比非遞歸算法要高。因為遞歸調(diào)用實際上是函數(shù)自己在調(diào)用自己,而函數(shù)的調(diào)用開銷很大,系統(tǒng)要為每次函數(shù)調(diào)用分配存儲空間,并將調(diào)用點壓棧予以記錄。而在函數(shù)調(diào)用結(jié)束后,還要釋放空間,彈?;謴?fù)斷點。所以說,函數(shù)調(diào)用不僅浪費空間,還浪費時間。
比如說,求n的階乘,其實如果使用迭代法來計算的話,他們的時間復(fù)雜度都是O(n),但是由于遞歸會需要多次發(fā)生函數(shù)調(diào)用,所以遞歸算法來計算的效率還是會低一些的。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,237評論 6 537
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,957評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 177,248評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,356評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 72,081評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,485評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,534評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,720評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,263評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 41,025評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,204評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,787評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,461評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,874評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,105評論 1 289
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,945評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 48,205評論 2 375

推薦閱讀更多精彩內(nèi)容