国产成人av人人爽人人澡-亚洲国产日韩欧美一区-好吊日视频这里只有精品-日本高清精品视频在线

您好,歡迎進入深圳市穎特新科技有限公司官方網站!

您現(xiàn)在的位置:首頁 新聞資訊 >> 新聞頭條 >> 函數(shù)的遞歸調用
新聞資訊
NEWS INFORMATION

函數(shù)的遞歸調用

發(fā)布時間:2019-05-22

一個函數(shù)在它的函數(shù)體內調用它自身稱為遞歸調用,這種函數(shù)稱為遞歸函數(shù)。執(zhí)行遞歸函數(shù)將反復調用其自身,每調用一次就進入新的一層。

【示例】用遞歸計算 n!。階乘 n! 的計算公式如下:

根據公式編程:

  1. long factorial(int n){
  2. long result;
  3. if(n==0 || n==1){
  4. result = 1;
  5. }else{
  6. result = factorial(n-1) * n; // 遞歸調用
  7. }
  8. return result;
  9. }

這是一個典型的遞歸函數(shù)。調用factorial后即進入函數(shù)體,只有當 n==0 或 n==1 時函數(shù)才會執(zhí)行結束,否則就一直調用它自身。

由于每次調用的實參為 n-1,即把 n-1 的值賦給形參 n,所以每次遞歸實參的值都減 1,直到最后 n-1 的值為 1 時再作遞歸調用,形參 n 的值也為1,遞歸就終止了,會逐層退出。

例如求 5!,即調用factorial(5)。當進入factorial函數(shù)體后,由于 n=5,不等于0或1,所以執(zhí)行result = factorial(n-1) * n;,即result = factorial(5-1) * 5;,接下來也就是調用factorial(4)。這是第一次遞歸。

進行四次遞歸調用后,實參的值為 1,也就是調用factorial(1)。這時遞歸就結束了,開始逐層返回。factorial(1) 的值為 1,factorial(2) 的值為 1*2=2,factorial(3) 的值為 2*3=6,factorial(4) 的值為 6*4=24,最后返回值 factorial(5) 為 24*5=120。

注意:為了防止遞歸調用無終止地進行,必須在函數(shù)內有終止遞歸調用的手段。常用的辦法是加條件判斷,滿足某種條件后就不再作遞歸調用,然后逐層返回。

遞歸調用不但難于理解,而且開銷很大,如非必要,不推薦使用遞歸。很多遞歸調用可以用迭代(循環(huán))來代替。

【示例】用迭代法求 n!。

  1. long factorial(int n){
  2. int i;
  3. long result=1;
  4. if(n==0 || n==1){
  5. return 1;
  6. }
  7. for(i=1; i<=n; i++){
  8. result *= i;
  9. }
  10. return result;
  11. }

關于函數(shù)調用的原理,請大家閱讀《C語言和內存》中的《棧的概念以及棧溢出》《一個函數(shù)在棧上到底是怎樣的》《詳細分析一個函數(shù)進棧出棧的例子》幾節(jié),屆時你將會明白遞歸調用的開銷為什么很大。

聯(lián)系方式0755-82591179

傳真:0755-82591176

郵箱:vicky@yingtexin.net

地址:深圳市龍華區(qū)民治街道民治大道973萬眾潤豐創(chuàng)業(yè)園A棟2樓A08

国产高清一区二区不卡| 亚洲中文在线中文字幕91| 国产精品亚洲精品亚洲| 日韩中文字幕在线不卡一区| 亚洲日本久久国产精品久久| 亚洲欧美日韩网友自拍| 亚洲精品熟女国产多毛 | 亚洲成人黄色一级大片| 日本加勒比在线观看一区| 我的性感妹妹在线观看| 亚洲欧洲日韩综合二区| 国产精品熟女乱色一区二区| 日韩在线视频精品视频| 国产欧美日韩综合精品二区| 成年人黄片大全在线观看| 亚洲一区二区三区精选| 欧洲一区二区三区蜜桃| 91亚洲精品亚洲国产| 色综合伊人天天综合网中文| 国产亚州欧美一区二区| 神马午夜福利免费视频| 国产亚洲中文日韩欧美综合网| 好吊视频一区二区在线| 日韩特级黄片免费在线观看| 人人妻人人澡人人夜夜| 福利新区一区二区人口| 老鸭窝精彩从这里蔓延| 夜色福利久久精品福利| 免费久久一级欧美特大黄孕妇| 久久精品久久久精品久久| 国产熟女一区二区三区四区| 亚洲一区二区精品免费| 青草草在线视频免费视频| 国产一区一一一区麻豆| 久久精品亚洲欧美日韩| 日韩黄色一级片免费收看| 国产日产欧美精品视频| 亚洲品质一区二区三区| 中文字幕五月婷婷免费| 麻豆国产精品一区二区| 欧美日韩一级黄片免费观看|