麻豆黑色丝袜jk制服福利网站-麻豆精品传媒视频观看-麻豆精品传媒一二三区在线视频-麻豆精选传媒4区2021-在线视频99-在线视频a

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 遞歸是什么?

遞歸是什么?

來源:千鋒教育
發布人:xqq
時間: 2023-10-10 23:57:07 1696953427

一、遞歸是什么

簡單地說,就是如果在函數中存在著調用函數本身的情況,這種現象就叫遞歸。遞歸的基本思想是某個函數直接或者間接地調用自身,這樣原問題的求解就轉換為了許多性質相同但是規模更小的子問題。求解時只需要關注如何把原問題劃分成符合條件的子問題,而不需要過分關注這個子問題是如何被解決的。

遞歸有三大要素

名列前茅要素:明確你這個函數想要干什么

對于遞歸,我覺得很重要的一個事就是,這個函數的功能是什么,他要完成什么樣的一件事,而這個,是完全由你自己來定義的。也就是說,我們先不管函數里面的代碼什么,而是要先明白,你這個函數是要用來干什么。

例如,我定義了一個函數

// 算 n 的階乘(假設n不為0)

int f(int n){

}

這個函數的功能是算 n 的階乘。好了,我們已經定義了一個函數,并且定義了它的功能是什么,接下來我們看第二要素。

第二要素:尋找遞歸結束條件

所謂遞歸,就是會在函數內部代碼中,調用這個函數本身,所以,我們必須要找出遞歸的結束條件,不然的話,會一直調用自己,進入無底洞。也就是說,我們需要找出當參數為啥時,遞歸結束,之后直接把結果返回,請注意,這個時候我們必須能根據這個參數的值,能夠直接知道函數的結果是什么。

例如,上面那個例子,當 n = 1 時,那你應該能夠直接知道 f(n) 是啥吧?此時,f(1) = 1。完善我們函數內部的代碼,把第二要素加進代碼里面,如下

// 算 n 的階乘(假設n不為0)

int f(int n){

??? if(n == 1){

??????? return 1;

??? }

}

有人可能會說,當 n = 2 時,那我們可以直接知道 f(n) 等于多少啊,那我可以把 n = 2 作為遞歸的結束條件嗎?

當然可以,只要你覺得參數是什么時,你能夠直接知道函數的結果,那么你就可以把這個參數作為結束的條件,所以下面這段代碼也是可以的。

// 算 n 的階乘(假設n>=2)

int f(int n){

??? if(n == 2){

??????? return 2;

??? }

}

注意我代碼里面寫的注釋,假設 n >= 2,因為如果 n = 1時,會被漏掉,當 n <= 2時,f(n) = n,所以為了更加嚴謹,我們可以寫成這樣:

// 算 n 的階乘(假設n不為0)

int f(int n){

??? if(n <= 2){

??????? return n;

??? }

}

第三要素:找出函數的等價關系式

第三要素就是,我們要不斷縮小參數的范圍,縮小之后,我們可以通過一些輔助的變量或者操作,使原函數的結果不變。

例如,f(n) 這個范圍比較大,我們可以讓 f(n) = n * f(n-1)。這樣,范圍就由 n 變成了 n-1 了,范圍變小了,并且為了原函數f(n) 不變,我們需要讓 f(n-1) 乘以 n。

說白了,就是要找到原函數的一個等價關系式,f(n) 的等價關系式為 n * f(n-1),即

f(n) = n * f(n-1)。

延伸閱讀;

二、遞歸的程序特性

優雅性

相比其他解法(比如迭代法),使用遞歸法,你會發現只需少量程序就可描述出解題過程,大大減少了程序的代碼量,而且很好理解。遞歸的能力在于用有限的語句來定義對象的無限集合。

反向性

由于遞歸調用程序需要維護調用棧,而棧(我們在上文提過)具有后進先出的特征,因此遞歸程序適合滿足取反類需求。我們在第五部分有一些編程實踐,比如字符串取反,鏈表取反等相關有趣的算法問題。

遞推關系

遞歸程序可以較明顯的發現遞推關系,反過來也可以這么說,具有遞推關系的問題基本都可以通過遞歸求解(當然也許有性能更佳的解法,但遞歸絕對是一種選擇)。遞推關系常見問題有楊輝三角、階乘計算。

聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
主站蜘蛛池模板: 秋霞影院国产| 欧美成人精品福利在线视频| 狠狠色狠狠色综合网| 一级影院| 国内国外精品影片无人区| 东北小彬系列chinese| 波多野结衣变态夫妻| 毛片无码国产| 夫妇野外交换hd中文小说| 欧美妈妈的朋友| 神宫寺奈绪jul055在线播放| 全球全球gogo专业摄影| 渣男渣女抹胸渣男渣女app| 波多野结衣护士系列播放| 老鸭窝在线免费视频| 波多野结衣女教师6bd| 日本三级电影网址| 天天想你在线视频免费观看| 污动漫3d| 欧美一区二区三区视频在线观看| 翁虹三级伦理电影大全在线观看| 海角社区视频在线| 中文乱码35页在线观看| 久久天天躁日日躁狠狠躁| 啊灬啊灬啊灬深灬快用力| 免费高清a级毛片在线播放| 天天操夜夜操| 国产三级在线免费观看| 亚洲精品动漫在线| 日韩欧美卡一卡二卡新区| 99久久精品费精品国产 | 久久国产成人精品国产成人亚洲| 被猛男cao男男粗大视频| 美女131爽| 欧美伊人久久大香线蕉在观| 一二三四视频社区在线| 悠悠在线观看精品视频| 极品丝袜乱系列全集| 国产亚洲美女精品久久久久| 日本三级生活片| 性做久久久久久久久|