什么是遞歸函數?

文章目錄

  • 遞歸函數
    • 遞歸
    • 例題
    • 特點
    • 效率
    • 優點

遞歸函數

遞歸

遞歸就是一個函數在它的函數體內調用它自身。執行遞歸函數將反復調用其自身,每調用一次就進入新的一層。遞歸函數必須有結束條件
當函數在一直遞推,直到遇到墻后返回,這個墻就是結束條件
所以遞歸要有兩個要素,結束條件與遞推關系

注:

遞歸的時候,每次調用一個函數,計算機都會為這個函數分配新的空間,這就是說,當被調函數返回的時候,調用函數中的變量依然會保持原先的值,否則也不可能實現反向輸出。

例題

  1. 計算n的階乘
#include <stdio.h> 
int factorial(int n)
{int result;if (n<0)                                          //判斷例外{printf("輸入錯誤!\n");return 0;} else if (n==0 || n==1){result = 1;  //回推墻}else{result = factorial(n-1) * n;  //遞推關系,這個數與上一個數之間的關系。}return result;
}int main(){int n = 5;                                              //輸入數字5,計算5的階乘printf("%d的階乘=%d",n,factorial(n));return 0;
}

程序在計算5的階乘的時候,先執行遞推,當n=1或者n=0的時候返回1,再回推將計算并返回。由此可以看出遞歸函數必須有結束條件

  1. 斐波那契數列

斐波那契數列指的是這樣一個數列:

0, 1, 1, 2, 3, 5, 8, 13, 21, ···

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

#include <stdio.h>long fibonacci( long num )
{if ( num == 0 || num == 1 ){return num;}else{return fibonacci( num -1 ) + fibonacci( num -2 );}
}void main()
{long number;puts("請輸入一個正整數: ");scanf("%ld", &number);printf("斐波那契數列第%ld項為: %ld\n", number, fibonacci( number ) );}

這里寫圖片描述

  1. 應用題~~

小明為了學好英語,需要每天記單詞,第一天記1個,第二天記2個依次類推,請用代碼完成,算出小明第10天開始的時候會了多少個單詞?

分析:
墻(結束條件)是“第一天記1個”
遞推關系是“第n天記的單詞= 第n-1天記的單詞數量+n"

#include <stdio.h>
/* 定義獲取單詞數量的函數 */
int getWordNumber(n)
{   if(n == 1){return 1;    //回推墻}else{return getWordNumber(n-1)+n ;       //遞推關系}
}
int main()
{int num = getWordNumber(10);     //獲取會了的單詞數量printf("小明第10天記了:%d個單詞。\n", num);return 0;
}

特點

遞歸函數特點:

1. 每一級函數調用時都有自己的變量,但是函數代碼并不會得到復制,如計算5的階乘時每遞推一次變量都不同;
2. 每次調用都會有一次返回,如計算5的階乘時每遞推一次都返回進行下一次;
3. 遞歸函數中,位于遞歸調用前的語句和各級被調用函數具有相同的執行順序;
4. 遞歸函數中,位于遞歸調用后的語句的執行順序和各個被調用函數的順序相反;
5. 遞歸函數中必須有終止語句。

一句話總結遞歸:自我調用且有完成狀態。

效率

  1. 系統棧(也叫核心棧、內核棧)
    是內存中屬于操作系統空間的一塊區域,其主要用途為: (1)保存中斷現場,對于嵌套中斷,被中斷程序的現場信息依次壓入系統棧,中斷返回時逆序彈出; (2)保存操作系統子程序間相互調用的參數、返回值、返回點以及子程序(函數)的局部變量。

  2. 用戶棧
    是用戶進程空間中的一塊區域,用于保存用戶進程的子程序間相互調用的參數、返回值、返回點以及子程序(函數)的局部變量。
    我們編寫的遞歸程序屬于用戶程序,因此使用的是用戶棧。

  3. 棧溢出
    函數調用的參數是通過棧空間來傳遞的,在調用過程中會占用線程的棧資源。而遞歸調用,只有走到最后的結束點后函數才能依次退出,而未到達最后的結束點之前,占用的棧空間一直沒有釋放,如果遞歸調用次數過多,就可能導致占用的棧資源超過線程的最大值,從而導致棧溢出,導致程序的異常退出。

綜上:

函數調用的時候,每次調用時要做地址保存,參數傳遞等,這是通過一個遞歸工作棧實現的。具體是每次調用函數本身要保存的內容包括:局部變量、形參、調用函數地址、返回值。那么,如果遞歸調用N次,就要分配N次局部變量、N次形參、N次調用函數地址、N次返回值,勢必效率低.

優點

  1. 代碼簡潔、清晰,易懂

循環能干的事,遞歸都能干;遞歸能干的循環不一定能干

對于我們,能用循環解決的,盡量不適用遞歸.

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/536145.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/536145.shtml
英文地址,請注明出處:http://en.pswp.cn/news/536145.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

apache ab壓力測試報錯

今天用apache 自帶的ab工具測試&#xff0c;當并發量達到1000多的時候報錯如下&#xff1a; [rootaa~]# This is ApacheBench, Version 2.3 <Revision:655654> Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/ Licensed to The Apache Sof…

ngOnInit與constructor的區別

前世今生 Angular會管理一個組件的生命周期,包括組件的創建、渲染、子組件創建與渲染、當數據綁定屬性變化時的校驗、DOM移除之前毀銷。 Angular提供組件生命周期鉤子便于我們在某些關鍵點發生時添加操作。 組件生命周期鉤子 指令和組件實例有個生命周期用于創建、更新和銷…

Nginx配置性能優化

大多數的Nginx安裝指南告訴你如下基礎知識——通過apt-get安裝&#xff0c;修改這里或那里的幾行配置&#xff0c;好了&#xff0c;你已經有了一個Web服務器了。而且&#xff0c;在大多數情況下&#xff0c;一個常規安裝的nginx對你的網站來說已經能很好地工作了。然而&#xf…

Angular的@Output與@Input理解

@Output與@Input理解 Output和Input是兩個裝飾器,是Angular2專門用來實現跨組件通訊,雙向綁定等操作所用的。 @Input Component本身是一種支持 nest 的結構,Child和Parent之間,如果Parent需要把數據傳輸給child并在child自己的頁面中顯示,則需要在Child的對應 directiv…

騰訊云CDN配置

第一步&#xff1a;先去領取騰訊云CDN免費包23333333 以下為正式步驟&#xff1a; 在這里體現大家&#xff0c;域名一定要備案&#xff0c;另外要明白域名如何解析 前邊問題不大&#xff0c;一切跟著騰訊云的套路來即可&#xff0c;需要注意的是網上后優化的配置大家可以自行…

Promise.all的深入理解

異步之Promise Promise.all Promise.all接收的promise數組是按順序執行的還是一起執行的&#xff0c;也就是說返回的結果是順序固定的嗎&#xff1f; 目前有兩種答案&#xff1a; 應該是同步執行的&#xff0c;但是這樣就有效率問題了&#xff0c;如果想改成異步執行怎么辦…

wordpress后臺無法登錄問題

之前給自己的WordPress加了個標簽云&#xff0c;今天登錄的時候突然發現網站后臺進不去了&#xff0c;無奈各種找材料&#xff0c;這算是皇天不負有心人&#xff0c;總算是給我找到了&#xff0c;現在做一下記錄 登錄不上的原因在于&#xff1a;wp-admin和wp-admin/是不同的&a…

深入理解Angular訂閱者模式

深入理解Angular訂閱者模式 如果正在讀此篇文章的你學過java,c++等面向對象語言,知道兩個模式觀察者模式和訂閱者模式,分別為:Observer pattern,Pub-sub pattern(Subscriber) 接下來我們結合Angular來說明這兩個模式。 Observer pattern This is a pattern of developme…

Ubuntu中安裝python3

通過命令行安裝Python3.*&#xff0c;只需要在終端中通過命令行安裝即可&#xff1a; sudo apt-get install python3 Ubuntu的底層大多數采用的是Python2.*&#xff0c;Python3和Python2是互相不兼容的&#xff0c;完全沒法通用的&#xff08;也不知道他們怎么想的o(TヘTo)&a…

Angular深入理解之指令

Angular深入理解之指令 指令有什么功能 Attribute directives 屬性指令Structural directives 結構指令自定義屬性指令自定義結構指令Angular深入理解之指令 對于初學Angular的同學來說,指令無疑是最痛苦的,那么我們怎么使用自定義的指令呢?指令到底怎么實現呢?為什么要寫…

windows下Apache虛擬主機配置

找到host文件&#xff1a;C:\Windows\System32\drivers\etc\hosts 在hosts這么增加&#xff1a; 127.0.0.1 666.666.com 127.0.0.1 777.777.com 修改httpd.conf文件&#xff1a; 打開文件&#xff1a;xxx\xampp\apache\conf\httpd.conf 找到#LoadModule vhost_…

Angular深入理解基本組成

Angular深入理解基本組成 在講指令時,我們先來了解一下Angular的基本概念和結構。 Module 模塊 Angular 是模塊化的.Modules 導出 classes, function, values , 以便在其他模塊導入使用.angular應用由模塊組成,每個模塊都做此模塊相關的事情組件、方法、類、服務等,他們都…

1607: 字符棱形

1607: 字符棱形 根據讀入的字符和邊長&#xff0c;勾畫字符棱形。 Input 輸入數據含有不超過50組的數據&#xff0c;每組數據包括一個可見字符c和一個整數n&#xff08;1≤n≤30&#xff09;。 Output 輸出以c為填充字符&#xff0c;邊長為n的棱形&#xff0c;勾畫每個棱形…

Angular深入理解管道Pipe

Angular深入理解管道 純管道與非純管道區別的本質 Pure FunctionImpure Function內置Pipe pipe使用自定義Pipe 管道性能優化Angular深入理解管道 管道的鏈接 有學過linux shell的同學,應該知道管道,在shell中的管道是IPC,linux的進程間通訊有pipe,FIFO,signal。這里只是簡單…

1959: 圖案打印

1959: 圖案打印 Description 一年一度的植樹節就要到了&#xff0c;計算機學院學生準備在學院教學樓門前的空地上種植樹木。為使樹木排列得更加美觀&#xff0c;大家決定把樹木排列成菱形。現在告訴你我們所擁有的樹木能排列成邊長為N的菱形&#xff0c;請你編程輸出樹木所排…

JS事件的捕獲和冒泡階段

JS事件的捕獲和冒泡階段 這里介紹兩個事件模型&#xff1a;IE事件模型與DOM事件模型 IE內核瀏覽器的事件模型是冒泡型事件&#xff08;沒有捕獲事件過程&#xff09;&#xff0c;事件句柄的觸發順序是從ChildNode到ParentNode。 <div id"ancestor"> <butt…

2016: C語言實驗——打印金字塔

2016: C語言實驗——打印金字塔 Description 輸入n值&#xff0c;打印下列形狀的金字塔&#xff0c;其中n代表金字塔的層數。 Input 輸入只有一個正整數n。 Output 打印金字塔圖形&#xff0c;其中每個數字之間有一個空格。 Sample Input 3 Sample Output 11 2 1 1 2 …

Anuglar中正確導入RxJS庫

Anuglar中正確導入RxJS庫 目前Angular2中的已經內建支持RxJS,所以我們在使用的時候可以直接導入使用了。 理解操作符導? 在使用創建依賴于 RxJS 組件,服務,指令等等時, 你可能遇到處理運算符導?的問 題。 在項?中引?操作符最主要的?式像下?這樣導?: import rxj…

1495: 蛇行矩陣

1495: 蛇行矩陣 Description 蛇形矩陣是由1開始的自然數依次排列成的一個矩陣上三角形。 Input 本題有多組數據&#xff0c;每組數據由一個正整數N組成。&#xff08;N不大于100&#xff09; Output 對于每一組數據&#xff0c;輸出一個N行的蛇形矩陣。兩組輸出之間不要額…

遞歸基礎之N皇后問題

遞歸基礎之N皇后問題 Description 在nn 格的棋盤上放置彼此不受攻擊的n 個皇后。按照國際象棋的規則&#xff0c;皇后可以攻擊與之 處在同一行或同一列或同一斜線上的棋子。n后問題等價于在nn格的棋盤上放置n個皇后&#xff0c; 任何2 個皇后不放在同一行或同一列或同一斜線上…