女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

遞歸指的是在函數的定義中使用函數自身的方法

電子工程師 ? 來源:未知 ? 作者:李倩 ? 2018-11-12 15:06 ? 次閱讀

遞歸指的是在函數的定義中使用函數自身的方法。

舉個例子:從前有座山,山里有座廟,廟里有個老和尚,正在給小和尚講故事呢!故事是什么呢?"從前有座山,山里有座廟,廟里有個老和尚,正在給小和尚講故事呢!故事是什么呢?'從前有座山,山里有座廟,廟里有個老和尚,正在給小和尚講故事呢!故事是什么呢?……'"

語法格式如下:

voidrecursion()

{ statements; ... ... ... recursion(); /* 函數調用自身 */ ... ... ...

}

intmain()

{ recursion();

}

流程圖:

C語言支持遞歸,即一個函數可以調用其自身。但在使用遞歸時,程序員需要注意定義一個從函數退出的條件,否則會進入死循環。

遞歸函數在解決許多數學問題上起了至關重要的作用,比如計算一個數的階乘、生成斐波那契數列,等等。

數的階乘

下面的實例使用遞歸函數計算一個給定的數的階乘:

#includedoublefactorial(unsignedinti)

{ if(i <= 1) ? { ? ? ?return1;

} returni * factorial(i - 1);

}

intmain()

{ inti = 15;

printf("%d 的階乘為 %f ", i, factorial(i));

return0;

}

當上面的代碼被編譯和執行時,它會產生下列結果:

15的階乘為1307674368000.000000

斐波那契數列

下面的實例使用遞歸函數生成一個給定的數的斐波那契數列:

#includeintfibonaci(inti)

{ if(i == 0) { return0;

} if(i == 1) { return1;

} returnfibonaci(i-1) + fibonaci(i-2);

}intmain()

{ inti;

for(i = 0; i < 10; i++) ? ?{ ? ? ? printf("%d ", fibonaci(i));

} return0;

}

當上面的代碼被編譯和執行時,它會產生下列結果:

0112358132134

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • C語言
    +關注

    關注

    180

    文章

    7630

    瀏覽量

    140283
  • 函數
    +關注

    關注

    3

    文章

    4368

    瀏覽量

    64182
  • 遞歸
    +關注

    關注

    0

    文章

    29

    瀏覽量

    9161

原文標題:C語言中的遞歸

文章出處:【微信號:c-stm32,微信公眾號:STM32嵌入式開發】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    快速掌握Python的遞歸函數與匿名函數調用

    好就容易畫虎不成反類犬,  b) Python中使用lambda關鍵字來創建匿名函數。所謂匿名,即不再使用def這種標準形式定義函數,需要
    發表于 07-19 16:22

    Labview遞歸函數的使用案例

    Labview遞歸函數的使用案例,簡單的1+2+3...+100求和,簡單易懂,充分理解遞歸函數的思想
    發表于 10-09 09:37

    matlab自定義函數調用的方法

    matlab自定義函數調用的方法 命令文件/函數文件+ 函數文件 - 多
    發表于 11-29 13:14 ?88次下載

    C++教程之函數遞歸調用

    C++教程之函數遞歸調用 執行函數 f 的過程中,又要調用 f 函數本身,稱為函數
    發表于 05-15 18:00 ?35次下載

    C++的實驗教程之函數遞歸算法資料免費下載

    函數遞歸算法 1.范例:求組合數, 一、實驗目的1. 學會解決簡單的遞歸算法。2. 掌握函數的嵌套調用。
    發表于 01-29 10:51 ?2次下載
    C++的實驗教程之<b class='flag-5'>函數</b>的<b class='flag-5'>遞歸</b>算法資料免費下載

    C語言函數的實驗詳細資料說明

    實驗目的和要求(1)掌握C語言函數定義方法函數的聲明及函數的調用方法。(2)掌握
    發表于 12-06 08:00 ?4次下載
    C語言<b class='flag-5'>函數</b>的實驗詳細資料說明

    PyTorch中使用ReLU激活函數的例子

    PyTorch已為我們實現了大多數常用的非線性激活函數,我們可以像使用任何其他的層那樣使用它們。讓我們快速看一個PyTorch中使用ReLU激活函數的例子:
    的頭像 發表于 07-06 15:27 ?2745次閱讀

    C語言-內聯函數遞歸函數、指針函數

    這篇文章介紹C語言的內聯函數遞歸函數函數指針、指針函數、局部地址、const關鍵字、extern關鍵字等知識點;這些知識點在實際項目開發
    的頭像 發表于 08-14 10:03 ?1923次閱讀

    C語言如何獲得自身定義函數的實際地址和大小嗎

    我們先看地址。C語言無法定義函數外標簽,函數內標簽從使用到訪問處處受限,我們好像只剩函數名可以用。但函數名表達式未必等同于
    發表于 12-02 10:52 ?1242次閱讀

    Python-函數的進階與遞歸

    程序開發中,有時候,會希望一個函數執行結束后,告訴調用者 **一個結果** ,以便調用者針對結果作后續的處理,返回值是函數完成工作后,最后給調用者的一個結果,
    的頭像 發表于 02-16 15:19 ?962次閱讀
    Python-<b class='flag-5'>函數</b>的進階與<b class='flag-5'>遞歸</b>

    Python支持遞歸函數

    Python支持遞歸函數——即直接或間接地調用自身以進行循環的函數遞歸是頗為高級的話題,并且它在Python中相對少見。然而,它是一項應該
    的頭像 發表于 02-21 14:28 ?776次閱讀

    函數遞歸-3

    程序調用自身的編程技巧稱為遞歸(recursion)。遞歸作為一種算法程序設計語言中廣泛應用。一個過程或函數在其
    的頭像 發表于 02-21 15:57 ?769次閱讀

    什么是Python的遞歸函數

    遞歸函數必須有終止條件。編程中,函數的調用要占用名叫棧(stack)的內存空間。調用函數時,程序會將相關的數據存儲到計算機的棧里。
    的頭像 發表于 02-23 10:25 ?2103次閱讀

    python定義函數與調用函數的順序

    定義函數與調用函數的順序 函數定義后,本身是不會自動執行的,只有在被調用后,函數才會被執行,得
    的頭像 發表于 10-04 17:17 ?1978次閱讀

    關于C語言中的遞歸

    遞歸指的是函數定義中使函數
    發表于 02-26 10:34 ?638次閱讀
    關于C語言中的<b class='flag-5'>遞歸</b>