亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

C語言程序中遞歸算法的使用實例教程

2020-01-26 14:37:57
字體:
來源:轉載
供稿:網友

1.問題:計算n!
數學上的計算公式為:

n!=n×(n-1)×(n-2)……2×1

使用遞歸的方式,可以定義為:

2016425152204144.jpg (313×64)

以遞歸的方式計算4!

F(4)=4×F(3)            遞歸階段F(3)=3×F(2)F(2)=2×F(1)F(1)=1  終止條件F(2)=(2)×(1)    回歸階段F(3)=(3)×(2)F(4)=(4)×(6)24                 遞歸完成

以遞歸方式實現階乘函數的實現:

int fact(int n) {  if(n < 0)    return 0;  else if (n == 0 || n == 1)    return 1;  else    return n * fact(n - 1);}

2.原理
下面來詳細分析遞歸的工作原理

先看看C語言中函數的執行方式,需要了解一些關于C程序在內存中的組織方式:

堆的增長方向為從低地址到高地址向上增長,而棧的增長方向剛好相反(實際情況與CPU的體系結構有關)。

當C程序中調用了一個函數時,棧中會分配一塊空間來保存與這個調用相關的信息,每一個調用都被當作是活躍的。棧上的那塊存儲空間稱為活躍記錄或者棧幀

棧幀由5個區域組成:輸入參數、返回值空間、計算表達式時用到的臨時存儲空間、函數調用時保存的狀態信息以及輸出參數,參見下圖:

2016425152248859.jpg (422×400)

可以使用下面的程序來檢驗:

#include <stdio.h>int g1=0, g2=0, g3=0;int max(int i){  int m1 = 0, m2, m3 = 0, *p_max;  static n1_max = 0, n2_max, n3_max = 0;  p_max = (int*)malloc(10);  printf("打印max程序地址/n");  printf("in max: 0x%08x/n/n",max);  printf("打印max傳入參數地址/n");  printf("in max: 0x%08x/n/n",&i);  printf("打印max函數中靜態變量地址/n");  printf("0x%08x/n",&n1_max); //打印各本地變量的內存地址  printf("0x%08x/n",&n2_max);  printf("0x%08x/n/n",&n3_max);  printf("打印max函數中局部變量地址/n");  printf("0x%08x/n",&m1); //打印各本地變量的內存地址  printf("0x%08x/n",&m2);  printf("0x%08x/n/n",&m3);  printf("打印max函數中malloc分配地址/n");  printf("0x%08x/n/n",p_max); //打印各本地變量的內存地址  if(i) return 1;  else return 0;}int main(int argc, char **argv){  static int s1=0, s2, s3=0;  int v1=0, v2, v3=0;  int *p;    p = (int*)malloc(10);  printf("打印各全局變量(已初始化)的內存地址/n");  printf("0x%08x/n",&g1); //打印各全局變量的內存地址  printf("0x%08x/n",&g2);  printf("0x%08x/n/n",&g3);  printf("======================/n");  printf("打印程序初始程序main地址/n");  printf("main: 0x%08x/n/n", main);  printf("打印主參地址/n");  printf("argv: 0x%08x/n/n",argv);  printf("打印各靜態變量的內存地址/n");  printf("0x%08x/n",&s1); //打印各靜態變量的內存地址  printf("0x%08x/n",&s2);  printf("0x%08x/n/n",&s3);  printf("打印各局部變量的內存地址/n");  printf("0x%08x/n",&v1); //打印各本地變量的內存地址  printf("0x%08x/n",&v2);  printf("0x%08x/n/n",&v3);  printf("打印malloc分配的堆地址/n");  printf("malloc: 0x%08x/n/n",p);  printf("======================/n");  max(v1);  printf("======================/n");  printf("打印子函數起始地址/n");  printf("max: 0x%08x/n/n",max);  return 0;}

棧是用來存儲函數調用信息的絕好方案,然而棧也有一些缺點:

棧維護了每個函數調用的信息直到函數返回后才釋放,這需要占用相當大的空間,尤其是在程序中使用了許多的遞歸調用的情況下。除此之外,因為有大量的信息需要保存和恢復,因此生成和銷毀活躍記錄需要消耗一定的時間。我們需要考慮采用迭代的方案。幸運的是我們可以采用一種稱為尾遞歸的特殊遞歸方式來避免前面提到的這些缺點。


3.斐波那契數列

#include <stdio.h>  int fibonacci(int a){//fibonacci數列,第一二項為1;后面的每一項為前兩項之和   if (a == 1 || a == 2)   {     return 1;   }else{     return fibonacci(a - 1) + fibonacci(a - 2);   } }  void main(){   printf("%d/n",fibonacci(40)); } 

 
4.遞歸將整形數字轉換為字符串

#include <stdio.h>  int toString(int i, char str[]){//遞歸將整形數字轉換為字符串   int j = 0;   char c = i % 10 + '0';   if (i /= 10)   {     j = toString(i, str) + 1;   }   str[j] = c;   str[j + 1] = '/0';   return j; }  void main(){   char str[100];   int i;   printf("enter a integer:/n");   scanf("%d",&i);   toString(i,str);   puts(str); } 

5.漢諾塔

#include <stdio.h>  void hanoi(int i,char x,char y,char z){   if(i == 1){     printf("%c -> %c/n",x,z);   }else{     hanoi(i - 1,x,z,y);     printf("%c -> %c/n",x,z);     hanoi(i - 1,y,x,z);   } }  void main(){   hanoi(10,'A','B','C'); } 

 
6.四個數找最大

int max(int a, int b, int c, int d){   if(a > b && a > c && a > d){     return a;   }else{     max(b,c,d,a);   } } 

7.猴子吃桃
每天吃一半再多吃一個,第十天想吃時候只剩一個,問總共有多少:

int chitao(int i){//猴子吃桃,每天吃一半再多吃一個,第十天想吃時候只剩一個   if(i == 10){     return 1;   }else{     return (chitao(i + 1) + 1) * 2;   } } 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美高清视频一区二区| 91av在线视频观看| 国产精品免费一区豆花| 久久久视频免费观看| 91国内免费在线视频| 国产免费观看久久黄| 91丝袜美腿美女视频网站| 欧美猛少妇色xxxxx| 精品福利在线视频| 欧洲美女7788成人免费视频| 68精品国产免费久久久久久婷婷| 中文字幕自拍vr一区二区三区| 欧美在线精品免播放器视频| 久久久视频免费观看| 最近中文字幕mv在线一区二区三区四区| 久久免费视频在线| 亚洲一区二区三区毛片| 日韩精品丝袜在线| 亚洲区免费影片| 日本成人免费在线| 欧美一区二区三区精品电影| 亚洲精品成人久久| 欧美福利视频网站| 国产精品久久久久久久久久ktv| 欧美猛交免费看| 久久精品夜夜夜夜夜久久| 精品成人69xx.xyz| 欧美一区二区大胆人体摄影专业网站| 久久av红桃一区二区小说| 狠狠久久亚洲欧美专区| 国产精品美女久久久免费| 精品国内亚洲在观看18黄| 久久精品成人一区二区三区| 久久精品国产欧美激情| 菠萝蜜影院一区二区免费| 色综合男人天堂| 精品亚洲一区二区三区在线观看| 日韩人在线观看| 国产精品一区二区三区免费视频| 色天天综合狠狠色| 欧美国产高跟鞋裸体秀xxxhd| 亚洲激情成人网| 青青草国产精品一区二区| 久久久久久久一| 欧美一区二区大胆人体摄影专业网站| 国产综合福利在线| 国产成人久久久精品一区| 色av吧综合网| 欧美激情2020午夜免费观看| 91久久国产婷婷一区二区| 欧美成人一区在线| 欧美国产日韩一区二区在线观看| 日韩欧美精品在线观看| 久久久久久久久国产| 欧美性猛交xxxx乱大交| 热久久美女精品天天吊色| 欧美电影免费观看高清完整| 久久久久日韩精品久久久男男| 最新69国产成人精品视频免费| 日韩av片免费在线观看| 亚州av一区二区| 国产成人精品一区二区在线| 成人中文字幕+乱码+中文字幕| 亚洲天堂免费视频| 久久久www成人免费精品| 欧美日韩亚洲高清| 精品亚洲国产视频| 91精品国产乱码久久久久久久久| 亚洲美女性生活视频| 亚洲自拍小视频免费观看| 亚洲一区二区久久久久久久| 欧美激情欧美狂野欧美精品| 青青草99啪国产免费| 91啪国产在线| 国产精品嫩草视频| 最近2019中文字幕在线高清| 亚洲性视频网址| 51午夜精品视频| 欧美黄色片视频| 久久99久久亚洲国产| 成人精品一区二区三区电影免费| 欧美区在线播放| 国产亚洲人成a一在线v站| 欧美最猛性xxxx| 欧美巨乳在线观看| 日韩不卡中文字幕| 国模gogo一区二区大胆私拍| 一区二区三区 在线观看视| 国产97在线视频| 欧美日韩中文字幕在线视频| 精品久久久久久国产91| 一个人www欧美| 国产精品视频网站| 日韩在线观看你懂的| 久久全球大尺度高清视频| 欧美日韩国产成人在线| 亚洲淫片在线视频| 国产精品久久一区| 日韩欧美精品在线观看| 欧美激情国产精品| 91九色视频导航| 国产精品视频专区| 亚洲国产99精品国自产| 热久久美女精品天天吊色| 欧美精品久久久久久久免费观看| 91成人在线播放| 欧美色欧美亚洲高清在线视频| 久久久久久久色| 亚洲人成电影在线| 美女国内精品自产拍在线播放| 久久久久久久久久久亚洲| 欧美夫妻性生活视频| 久久久久久久久久久亚洲| 亚洲国产天堂久久综合网| 久久久天堂国产精品女人| 2019日本中文字幕| 国产精品18久久久久久麻辣| 日韩欧美国产视频| 亚洲第一av在线| 日韩电影中文字幕在线| 亚洲桃花岛网站| 欧美日韩激情小视频| 国产日韩精品一区二区| 欧美性猛交xxxx黑人猛交| 久久人人爽人人爽爽久久| 久久久久久av| 欧美裸体xxxx极品少妇| 国产精品69精品一区二区三区| 久久久精品2019中文字幕神马| 日本高清视频一区| 精品久久久久久久久久久| 欧美黄色免费网站| 欧美激情奇米色| 亚洲欧美日韩第一区| 精品偷拍一区二区三区在线看| 在线电影av不卡网址| 最近2019中文字幕一页二页| 国产精品精品久久久| 欧美成人亚洲成人日韩成人| 亚洲欧洲中文天堂| 国产精品日本精品| 日韩va亚洲va欧洲va国产| 精品美女久久久久久免费| 成人精品在线观看| 国产精品美女在线观看| 国产午夜精品久久久| 一区二区三区四区视频| 日本高清不卡在线| 亚洲永久在线观看| 午夜免费在线观看精品视频| 欧美国产视频日韩| 亚洲精品一区二区久| 亚洲白拍色综合图区| 亚洲香蕉成视频在线观看| 91香蕉嫩草神马影院在线观看| 国产精品专区一| 97av在线视频免费播放| 久久久久久久香蕉网| 97碰碰碰免费色视频| 热久久免费视频精品| 插插插亚洲综合网| 久久久成人精品视频| 黑人精品xxx一区一二区| 精品亚洲国产视频|