千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構

手機站
千鋒教育

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

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

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

當前位置:首頁  >  技術干貨  > 遞歸有什么優(yōu)缺點?

遞歸有什么優(yōu)缺點?

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-10-10 23:54:36 1696953276

一、遞歸的優(yōu)缺點

遞歸是什么

程序調(diào)用自身的編程技巧稱為遞歸( recursion)。遞歸做為一種算法在程序設計語言中廣泛應用。

一個過程或函數(shù)在其定義或說明中有直接或間接調(diào)用自身的一種方法,它通常把一個大型復雜的問題層層轉化為一個與原問題相似的規(guī)模較小的問題來求解,遞歸策略只需少量的程序就可描述出解題過程所需要的多次重復計算,大大地減少了程序的代碼量。

遞歸的能力在于用有限的語句來定義對象的無限集合。一般來說,遞歸需要有邊界條件、遞歸前進段和遞歸返回段。當邊界條件不滿足時,遞歸前進;當邊界條件滿足時,遞歸返回。

遞歸的優(yōu)缺點

優(yōu)點:代碼更簡潔清晰,可讀性更好

遞歸的話函數(shù)調(diào)用是有開銷的,而且遞歸的次數(shù)受堆棧大小的限制。

缺點:

時間和空間消耗比較大。每一次函數(shù)調(diào)用都需要在內(nèi)存棧中分配空間以保存參數(shù),返回地址以及臨時變量,而且往棧里面壓入數(shù)據(jù)和彈出都需要時間。

另外遞歸會有重復的計算。遞歸本質(zhì)是把一個問題分解為多個問題,如果這多個問題存在重復計算,有時候會隨著n成指數(shù)增長。斐波那契的遞歸就是一個例子。

遞歸還有棧溢出的問題,每個進程的棧容量是有限的。由于遞歸需要系統(tǒng)堆棧,所以空間消耗要比非遞歸代碼要大很多。而且,如果遞歸深度太大,可能系統(tǒng)撐不住。

延伸閱讀:

二、遞歸的程序特性

優(yōu)雅性

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

反向性

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

遞推關系

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

聲明:本站稿件版權均屬千鋒教育所有,未經(jīng)許可不得擅自轉載。
10年以上業(yè)內(nèi)強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您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
久久亚洲中文字幕精品一区四,亚洲日本另类欧美一区二区,久久久久久久这里只有免费费精品,高清国产激情视频在线观看
亚洲欧美综合一区另类 | 日本一二三区性视频 | 亚洲国产专区校园欧美 | 在线免费播放的AV网站 | 亚洲精品中文AV字幕乱码 | 亚洲性色在线视频 |