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

首頁 > 學院 > 開發設計 > 正文

C語言初學者入門講座 第十講 函數(3)

2019-11-17 05:42:04
字體:
來源:轉載
供稿:網友

  函數的遞歸調用

  一個函數在它的函數體內調用它自身稱為遞歸調用。 這種函數稱為遞歸函數。C語言答應函數的遞歸調用。在遞歸調用中, 主調函數又是被調函數。執行遞歸函數將反復調用其自身。 每調用一次就進入新的一層。例如有函數f如下:

int f (int x)
{
int y;
z=f(y);
return z;
}

  這個函數是一個遞歸函數。 但是運行該函數將無休止地調用其自身,這當然是不正確的。為了防止遞歸調用無終止地進行, 必須在函數內有終止遞歸調用的手段。常用的辦法是加條件判定, 滿足某種條件后就不再作遞歸調用,然后逐層返回。 下面舉例說明遞歸調用的執行過程。

  [例5.9]用遞歸法計算n!用遞歸法計算n!可用下述公式表示:

n!=1 (n=0,1)
n×(n-1)! (n>1)
按公式可編程如下:
long ff(int n)
{
long f;
if(n<0) PRintf("n<0,input error");
else if(n==0n==1) f=1;
else f=ff(n-1)*n;
return(f);
}
main()
{
int n;
long y;
printf("/ninput a inteager number:/n");
scanf("%d",&n);
y=ff(n);
printf("%d!=%ld",n,y);
}
long ff(int n)
{ ……
else f=ff(n-1)*n;
……
}
main()
{ ……
y=ff(n);
……
}  

  程序中給出的函數ff是一個遞歸函數。主函數調用ff 后即進入函數ff執行,假如n<0,n==0或n=1時都將結束函數的執行,否則就遞歸調用ff函數自身。由于每次遞歸調用的實參為n-1,即把n-1 的值賦予形參n,最后當n-1的值為1時再作遞歸調用,形參n的值也為1,將使遞歸終止。然后可逐層退回。下面我們再舉例說明該過程。 設執行本程序時輸入為5, 即求 5!。在主函數中的調用語句即為y=ff(5),進入ff函數后,由于n=5,不等于0或1,故應執行f=ff(n-1)*n,即f=ff(5-1)*5。該語句對ff作遞歸調用即ff(4)。 逐次遞歸展開如圖5.3所示。進行四次遞歸調用后,ff函數形參取得的值變為1,故不再繼續遞歸調用而開始逐層返回主調函數。ff(1)的函數返回值為1,ff(2)的返回值為1*2=2,ff(3)的返回值為2*3=6,ff(4) 的返回值為6*4=24,最后返回值ff(5)為24*5=120。

  例5. 9也可以不用遞歸的方法來完成。如可以用遞推法,即從1開始乘以2,再乘以3…直到n。遞推法比遞歸法更輕易理解和實現。但是有些問題則只能用遞歸算法才能實現。典型的問題是Hanoi塔問題。
  
  [例5.10]Hanoi塔問題

  一塊板上有三根針,A,B,C。A針上套有64個大小不等的圓盤, 大的在下,小的在上。如圖5.4所示。要把這64個圓盤從A針移動C針上,每次只能移動一個圓盤,移動可以借助B針進行。但在任何時候,任何針上的圓盤都必須保持大盤在下,小盤在上。求移動的步驟。

  本題算法分析如下,設A上有n個盤子。

  假如n=1,則將圓盤從A直接移動到C。

  假如n=2,則:

  1.將A上的n-1(等于1)個圓盤移到B上;

  2.再將A上的一個圓盤移到C上;

  3.最后將B上的n-1(等于1)個圓盤移到C上。

  假如n=3,則:

  A. 將A上的n-1(等于2,令其為n`)個圓盤移到B(借助于C),

  步驟如下:

  (1)將A上的n`-1(等于1)個圓盤移到C上,見圖5.5(b)。

  (2)將A上的一個圓盤移到B,見圖5.5(c)

  (3)將C上的n`-1(等于1)個圓盤移到B,見圖5.5(d)

  B. 將A上的一個圓盤移到C,見圖5.5(e)

  C. 將B上的n-1(等于2,令其為n`)個圓盤移到C(借助A),

  步驟如下:

  (1)將B上的n`-1(等于1)個圓盤移到A,見圖5.5(f)

  (2)將B上的一個盤子移到C,見圖5.5(g)

  (3)將A上的n`-1(等于1)個圓盤移到C,見圖5.5(h)。

  到此,完成了三個圓盤的移動過程。

  從上面分析可以看出,當n大于等于2時, 移動的過程可分解為三個步驟:

  第一步 把A上的n-1個圓盤移到B上;

  第二步 把A上的一個圓盤移到C上;

  第三步 把B上的n-1個圓盤移到C上;其中第一步和第三步是類同的。

  當n=3時,第一步和第三步又分解為類同的三步,即把n`-1個圓盤從一個針移到另一個針上,這里的n`=n-1。 顯然這是一個遞歸過
程,據此算法可編程如下:

move(int n,int x,int y,int z)
{
if(n==1)
printf("%c-->%c/n",x,z);
else
{
move(n-1,x,z,y);
printf("%c-->%c/n",x,z);
move(n-1,y,x,z);
}
}
main()
{
int h;
printf("/ninput number:/n");
scanf("%d",&h);
printf("the step to moving %2d diskes:/n",h);
move(h,'a','b','c');
}
move(int n,int x,int y,int z)
{
if(n==1)
printf("%-->%c/n",x,z);
else
{
move(n-1,x,z,y);
printf("%c-->%c/n",x,z);
move(n-1,y,x,z);
}
}
main()
{ ……
move(h,'a','b','c');
}

  從程序中可以看出,move函數是一個遞歸函數,它有四個形參n,x,y,z。n表示圓盤數,x,y,z分別表示三根針。move 函數的功能是把x上的n個圓盤移動到z 上。當n==1時,直接把x上的圓盤移至z上,輸出x→z。如n!=1則分為三步:遞歸調用move函數,把n-1個圓盤從x移到y;輸出x→z;遞歸調用move函數,把n-1個圓盤從y移到z。在遞歸調用過程中n=n-1,故n的值逐次遞減,最后n=1時,終止遞歸,逐層返回。當n=4 時程序運行的結果為

input number:
4
the step to moving 4 diskes:
a→b
a→c
b→c
a→b
c→a
c→b
a→b
a→c
b→c
b→a
c→a
b→c
a→b
a→c
b→c


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人性生交大片免费观看嘿嘿视频| 久久人人看视频| 国产日韩欧美在线视频观看| 亚洲人成网站777色婷婷| 久久精品国产一区二区电影| 亚洲性av网站| 亚洲精品久久久久久久久久久久| 亚洲色图15p| 亚洲人精品午夜在线观看| 中文字幕亚洲欧美日韩高清| 日本国产欧美一区二区三区| 欧美日韩一二三四五区| 97超级碰在线看视频免费在线看| 久久久久久一区二区三区| 国产做受69高潮| 亚洲国产精品va| www.欧美免费| 国内精品小视频在线观看| 91手机视频在线观看| 久久成年人免费电影| 亚洲大胆美女视频| 欧美电影在线观看高清| 姬川优奈aav一区二区| 欧美肥老太性生活视频| 97色在线观看免费视频| 欧美日韩午夜激情| 亚洲欧美日韩精品久久亚洲区| 日韩暖暖在线视频| 欧美做爰性生交视频| 欧美有码在线观看视频| 亚洲欧美制服综合另类| 久久电影一区二区| 欧美裸体xxxx极品少妇软件| 亚洲欧美资源在线| 日韩美女视频免费在线观看| 午夜精品久久久久久久白皮肤| 国产91成人video| 国产精品成人av在线| 亚洲人成网站777色婷婷| 55夜色66夜色国产精品视频| 欧美专区第一页| 国产精品极品在线| 国产福利成人在线| 欧美怡春院一区二区三区| 欧美成人精品激情在线观看| 欧美精品激情视频| www.欧美视频| 国产免费一区视频观看免费| 色诱女教师一区二区三区| 日本精品免费一区二区三区| 国产裸体写真av一区二区| 日韩免费在线视频| 色先锋资源久久综合5566| 亚洲欧美日韩中文在线制服| 亚洲国产日韩一区| 奇米一区二区三区四区久久| 精品久久久香蕉免费精品视频| 欧美性猛交xxxxx水多| 午夜精品理论片| 国产精品久久久久影院日本| 97国产精品视频| 久久精品视频导航| 欧美孕妇与黑人孕交| 久久精品久久久久久国产 免费| 日韩一区二区欧美| 国产成人一区二| 中文字幕日韩av| 精品国产欧美成人夜夜嗨| 日韩极品精品视频免费观看| www.欧美精品一二三区| 国产成人久久久精品一区| 伊人久久男人天堂| 亚洲高清不卡av| 久久影视三级福利片| 欧美专区国产专区| 日韩va亚洲va欧洲va国产| 亚洲第一偷拍网| 97精品视频在线播放| 91亚洲va在线va天堂va国| 欧洲永久精品大片ww免费漫画| 久久久久久久久国产精品| 成人黄色在线免费| 国产亚洲xxx| 日韩在线观看精品| 91色视频在线观看| 国产精品久久久久久久久男| 日韩电影中文 亚洲精品乱码| 国产日本欧美在线观看| 亚洲国产欧美精品| 3344国产精品免费看| 66m—66摸成人免费视频| 国产精品igao视频| 91欧美精品午夜性色福利在线| 国产91精品久久久| 乱亲女秽乱长久久久| 91久久久久久| 亚洲自拍偷拍福利| 992tv在线成人免费观看| 91高潮精品免费porn| 日韩av色综合| 成人h片在线播放免费网站| www.久久久久| 国内久久久精品| 中文字幕欧美日韩在线| 国产xxx69麻豆国语对白| 欧洲亚洲在线视频| 欧美激情一级二级| 亚洲精品日产aⅴ| 久久好看免费视频| 欧美高清无遮挡| 亚洲美女黄色片| 色综合亚洲精品激情狠狠| 91精品国产91久久久久久| 亚洲精品成人久久久| 国产九九精品视频| 最好看的2019年中文视频| 色阁综合伊人av| 精品无码久久久久久国产| 久久综合国产精品台湾中文娱乐网| 国产精品高精视频免费| 日韩**中文字幕毛片| 日韩欧美高清在线视频| 亚洲综合小说区| 欧美日韩黄色大片| 欧亚精品中文字幕| 日本精品性网站在线观看| 亚洲国产成人精品电影| 91免费电影网站| 国产精品久久久久久久久久久久久| 亚洲国产古装精品网站| 97婷婷大伊香蕉精品视频| 97久久精品人搡人人玩| 高清欧美性猛交xxxx| 精品国产福利在线| 国产精品视频中文字幕91| 成人午夜在线观看| 亚洲第一视频网| 欧美夫妻性生活xx| 日韩精品免费视频| 国产精品免费看久久久香蕉| 国产大片精品免费永久看nba| 亚洲图片欧洲图片av| 日本欧美国产在线| 亚洲欧美另类人妖| 亚洲成年网站在线观看| 久久黄色av网站| 高跟丝袜欧美一区| 日韩av网址在线观看| 欧美日本国产在线| 国产精品视频男人的天堂| 神马久久久久久| 一本色道久久88精品综合| 欧美麻豆久久久久久中文| 夜夜嗨av色一区二区不卡| 精品中文字幕在线2019| 国产成人精品午夜| 九九久久久久久久久激情| 91夜夜未满十八勿入爽爽影院| 成人女保姆的销魂服务| 91久久精品美女| 国产剧情日韩欧美| 精品亚洲一区二区三区四区五区| 日韩在线视频线视频免费网站| 免费99精品国产自在在线|