關(guān)于遞歸法

一個(gè)過(guò)程或函數(shù)在其定義或說(shuō)明中又直接或間接調(diào)用自身的一種方法,它通常把一個(gè)大型復(fù)雜的問題轉(zhuǎn)化為一個(gè)與原問題相似的規(guī)模較小的問題來(lái)求解燥翅,遞歸策略只需少量的程序就可描述出解題過(guò)程所需要的多次重復(fù)計(jì)算柬讨,大大地減少了程序的代碼量罚舱。遞歸的能力在于用有限的語(yǔ)句來(lái)定義對(duì)象的無(wú)限集合继薛。一般來(lái)說(shuō)饲齐,遞歸需要有邊界條件诫隅、遞歸前進(jìn)段和遞歸返回段腐魂。當(dāng)邊界條件不滿足時(shí),遞歸前進(jìn)逐纬;當(dāng)邊界條件滿足時(shí)蛔屹,遞歸返回。

遞歸算法一般用于解決三類問題:

(1)數(shù)據(jù)的定義是按遞歸定義的风题。(Fibonacci函數(shù))

(2)問題解法按遞歸算法實(shí)現(xiàn)判导。(回溯)

(3)數(shù)據(jù)的結(jié)構(gòu)形式是按遞歸定義的。(樹的遍歷沛硅,圖的搜索)


遞歸的執(zhí)行過(guò)程可分為分解和求值兩部分眼刃。首先是逐步把“大問題”分解成形式相同但規(guī)模很小的“小問題”,直至分解到遞歸出口摇肌。一旦遇到遞歸出口擂红,分解過(guò)程結(jié)束,開始求值過(guò)程,所以分解過(guò)程是“量變”過(guò)程昵骤,即原來(lái)的“大問題”在慢慢變小树碱,但尚未解決。遇到遞歸出口后变秦,便發(fā)生了“質(zhì)變”成榜,即原遞歸問題轉(zhuǎn)換成直接可以求值的簡(jiǎn)單問題。遞歸只需要少量的步驟就可描述解題過(guò)程中所需要的多次重復(fù)計(jì)算蹦玫,極大地減少了代碼量赎婚。該算法設(shè)計(jì)的關(guān)鍵在于,找出遞歸方程和邊界條件(遞歸出口)樱溉。遞歸關(guān)系就是使問題向邊界條件轉(zhuǎn)化的過(guò)程挣输,所以遞歸關(guān)系必須能使問題越來(lái)越簡(jiǎn)單,規(guī)模越小福贞。沒有設(shè)定邊界的遞歸是死循環(huán)撩嚼。

遞歸算法設(shè)計(jì)通常需要按照以下3個(gè)步驟:

(1)分析問題,得出遞歸關(guān)系挖帘;

(2)設(shè)置邊界條件完丽,控制遞歸;

(3)設(shè)計(jì)函數(shù)肠套,確定參數(shù)舰涌。


遞歸算法具有以下三個(gè)基本規(guī)則:

(1)基本情形:至少有一種無(wú)需遞歸即可獲得解決的情形,也即前面說(shuō)的邊界條件你稚。

(2)進(jìn)展:任意遞歸調(diào)用必須向基本情形邁進(jìn)瓷耙,即前面所說(shuō)的使得問題規(guī)模變小。

(3)正確性假設(shè):總是假設(shè)遞歸調(diào)用是有效的刁赖。

遞歸調(diào)用的有效性是可以用數(shù)學(xué)歸納法證明的搁痛,所以當(dāng)我們?cè)谠O(shè)計(jì)遞歸函數(shù)時(shí),不必設(shè)法跟蹤可能很長(zhǎng)的遞歸調(diào)用途徑(比如Hanoi Tower問題)宇弛。這種任務(wù)可能很麻煩鸡典,易于使設(shè)計(jì)和驗(yàn)證變得更加困難。所以我們一旦決定使用遞歸算法枪芒,則必須假設(shè)遞歸調(diào)用是有效的彻况。


與遞歸相對(duì)應(yīng)的遞推算法是一種用若干步可重復(fù)的簡(jiǎn)單運(yùn)算(規(guī)律)來(lái)描述復(fù)雜問題的方法。

遞推算法以初始(起點(diǎn))值為基礎(chǔ)舅踪,用相同的運(yùn)算規(guī)律纽甘,逐次重復(fù)運(yùn)算,直至運(yùn)算結(jié)束抽碌。這種從“起點(diǎn)”重復(fù)相同的方法直至到達(dá)一定“邊界”悍赢,猶如單向運(yùn)動(dòng),用循環(huán)可以實(shí)現(xiàn)。遞推的本質(zhì)是按規(guī)律逐次推出(計(jì)算)先一步的結(jié)果左权。

在算法設(shè)計(jì)時(shí)皮胡,能用遞推實(shí)現(xiàn)的算法一般都可以用遞歸來(lái)實(shí)現(xiàn)。能用遞歸實(shí)現(xiàn)的算法不一定能夠通過(guò)遞推實(shí)現(xiàn)赏迟。就算法的效率而言屡贺,遞推優(yōu)于遞歸

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市瀑梗,隨后出現(xiàn)的幾起案子烹笔,更是在濱河造成了極大的恐慌,老刑警劉巖抛丽,帶你破解...
    沈念sama閱讀 218,122評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異饰豺,居然都是意外死亡亿鲜,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門冤吨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)蒿柳,“玉大人,你說(shuō)我怎么就攤上這事漩蟆±萏剑” “怎么了?”我有些...
    開封第一講書人閱讀 164,491評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵怠李,是天一觀的道長(zhǎng)圾叼。 經(jīng)常有香客問我,道長(zhǎng)捺癞,這世上最難降的妖魔是什么夷蚊? 我笑而不...
    開封第一講書人閱讀 58,636評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮髓介,結(jié)果婚禮上惕鼓,老公的妹妹穿的比我還像新娘。我一直安慰自己唐础,他們只是感情好箱歧,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,676評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著一膨,像睡著了一般须妻。 火紅的嫁衣襯著肌膚如雪凿滤。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,541評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音福侈,去河邊找鬼换棚。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的豺型。 我是一名探鬼主播,決...
    沈念sama閱讀 40,292評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼买乃,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼姻氨!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起剪验,我...
    開封第一講書人閱讀 39,211評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤肴焊,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后功戚,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體娶眷,經(jīng)...
    沈念sama閱讀 45,655評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,846評(píng)論 3 336
  • 正文 我和宋清朗相戀三年啸臀,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了届宠。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,965評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡乘粒,死狀恐怖豌注,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情灯萍,我是刑警寧澤轧铁,帶...
    沈念sama閱讀 35,684評(píng)論 5 347
  • 正文 年R本政府宣布,位于F島的核電站旦棉,受9級(jí)特大地震影響齿风,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜他爸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,295評(píng)論 3 329
  • 文/蒙蒙 一聂宾、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧诊笤,春花似錦系谐、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至晾匠,卻和暖如春茶袒,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背凉馆。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工薪寓, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留亡资,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,126評(píng)論 3 370
  • 正文 我出身青樓向叉,卻偏偏與公主長(zhǎng)得像锥腻,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子母谎,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,914評(píng)論 2 355

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

  • 遞歸法: 通過(guò)自身調(diào)用自身來(lái)達(dá)到問題解決的算法瘦黑。一般,我們用歸納法是證明遞歸算法正確性和進(jìn)行算法分析 原問題無(wú)法解...
    _屬于我閱讀 2,187評(píng)論 0 2
  • # 窮舉(枚舉懈贺、暴力演顾、強(qiáng)力)算法 ## 基本思想 在可能的解空間中窮舉出每一種可能的解,并對(duì)每一個(gè)可能解進(jìn)行判斷隅居,...
    Tenloy閱讀 5,121評(píng)論 0 7
  • ??腦抽的我上個(gè)文章爛尾,又開新坑葛虐,胎源,,屿脐,我只能對(duì)自己前面開的爛坑說(shuō)一句:青山不改涕蚤,綠水長(zhǎng)流,我們有緣再見的诵!??這...
    大王叫我來(lái)巡老和山閱讀 1,367評(píng)論 0 6
  • 本文主要介紹的遞歸算法万栅。 首先我們看下百度百科對(duì)遞歸的基本概念:程序調(diào)用自身的編程技巧稱為 遞歸( recursi...
    騎小豬看流星閱讀 1,250評(píng)論 0 11
  • 設(shè)一個(gè)未知函數(shù)f,用其自身構(gòu)成的已知函數(shù)g來(lái)定義:f(n)=g(n ,f(n-1))n>0f(0)=an=0為了定...
    陽(yáng)光的技術(shù)小棧閱讀 2,278評(píng)論 0 0