




下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
6.4補(bǔ)考練習(xí)題及參考答案6.4.1單項選擇題1.遞歸函數(shù)f(n)=f(n-1)+n(n>1)的遞歸出口是A.f⑴=1B.f⑴=0C.f(0)=0D.f(n)=n答:當(dāng)n=0時,f⑴=0。本題答案為B。2.遞歸函數(shù)f(n)=f(n-1)+n(n>1)的遞歸體是A.f(1)=1B.f(0)=0C.f(n)=f(n-1)+nD.f(n)=n答:遞歸體反映遞歸過程。本題答案為C。3.f(n)=占+上+…+1和司,遞歸模型為A.f(n)=-^-1x221+3.f(n)=占+上+…+1和司,遞歸模型為A.f(n)=-^-1x221++…+2x3nx(n—1)B.f(n)=1+—+...+——1—+f(n-1)1x22x3(n-1)xnC.f(1)=1f(n)=f(n-1)+/1A2nx(n-1)D.f(n)=f(n-1)+/1Anx(n一1)答:遞歸模型由兩部分組成,一是遞歸出口,另一是遞歸體,上述選項中只有C符合條件。本答案為C。4.將遞歸算法轉(zhuǎn)換成對應(yīng)的非遞歸算法時,通常需要使用保存中間結(jié)果。A.隊列B.棧C.鏈表D.樹答:遞歸計算過程是:先進(jìn)行遞歸分解,知道遞歸出口為止,然后根據(jù)遞歸出口的結(jié)果反過來求值。這樣通常需要后面的遞推式先計算出結(jié)果,這正好滿足棧的特點。所以本題答案為B。6.4.2填空題1.將h,轉(zhuǎn)化成遞歸函數(shù),其遞歸出口是―①,遞歸體是―②—答:①f(1)=0②f(n)=f(n-1)+inti;if(w!=1){print(wT);for(i=1;i<=w;i++)printf(“%3d”,w);printf("\n”);}}調(diào)用語句print(4)的結(jié)果是。答:1223334444有如下遞歸過程:voidreverse(intm){printf("%d”,n%100);if(n/10!=0)reverse(n/10);}調(diào)用語句reverse(582)的結(jié)果是。答:reverse()函數(shù)將給定的參數(shù)逆轉(zhuǎn)。本題答案為:285.6.4.3判斷題判斷以下敘述的正確性。任何遞歸算法都有遞歸出口。遞歸算法的執(zhí)行效率比功能相同的非遞歸算法的執(zhí)行效率高。遞歸算法不能轉(zhuǎn)換成對應(yīng)的非遞歸算法。答:(1)正確。錯誤。通常情況下遞歸算法的執(zhí)行效率比功能相同的非遞歸算法的執(zhí)行效率低。錯誤??梢杂脳⑦f歸算法轉(zhuǎn)換成對應(yīng)的非遞歸算法。6.4.3簡答題設(shè)a是含有n個元素的整數(shù)數(shù)組。寫出求n個整數(shù)之和的遞歸定義。寫出求n個整數(shù)之積的遞歸定義。答:假定數(shù)組a的下標(biāo)從0開始。設(shè)f(a,i)返回a[0]?a[i-1]元素之和。當(dāng)i=1,f(a,1)=a[0];假設(shè)數(shù)組a的前i-1個元素之和已經(jīng)求出,即已知f(a,i-1),則f(a,i)=f(a,i-1)xa[i-1],所以得到以下遞歸定義:f(a,1)=a[0]f(a,i)=f(a,i-1)+a[i-1]a中n個整數(shù)之和=f(a,n)。設(shè)f(a,i)返回a[0]?a[i-1]元素之積。當(dāng)i=1,f(a,1)=a[0];假設(shè)數(shù)組a的前i-1個元素之積已經(jīng)求出,即已知f(a,i-1),則f(a,i)=f(a,i-1)xa[i-1],所以得到以下遞歸定義:f(a,1)=a[0]f(a,i)=f(a,i-1)xa[i-1]a中n個整數(shù)之積=f(a,n)。以下算法是計算兩個正整數(shù)u和v最大公因數(shù)的遞歸函數(shù),給出其遞歸模型。intgcd(intu,intv){intr;if((r=u%v)==0)return(v);elsereturn(gcd(u,r));}答:由上述函數(shù)得到如下遞歸模型如下:gcd(u,v)=v當(dāng)u%v=0時gcd(u,v)=gcd(u,u%v)其他情況6.4.4算法設(shè)計題編寫一個遞歸過程,它讀入一串任意長的字符串,該串字符以“.”作為結(jié)束,要求打印出它們的倒序字符串。解:首先獲取用戶按鍵,如果不是.字符,則遞歸調(diào)用該過程,否則顯示該字符。對應(yīng)的算法如下:voidreverse()charch;scanf("%c”,&ch);if(ch!=‘.’){reverse();printf("%c”,ch);}}全排列問題:輸An個不同的字符,給出它們所有的n個字符的全排列。解:將n個不同的字符存放在字符串str中,求解全排列問題的遞歸模型如下:perm(str,k,n):輸出產(chǎn)生的解若k=n-1perm(str,k,n):對于k?n-1的i,str[i]與str[k]交換位置;其他情況perm(str,k+1,n);將str[k]與str[i]交換位置;/*回復(fù)環(huán)境*/對應(yīng)的算法如下:voidprint(charstr[],intn)/*輸出一個排列*/{for(inti=0;i<n;i++)printf("%c”,str[i]);printf("\n”);}voidperm(charstr[],intk,intn)inti;chartemp;if(k==n-1)print(str,n);else{for(i=k;i<n;i++){temp=str[k];/*交換str[k]與str[i]*/str[k]=str[i];str[i]=temp;perm(str,k+1,n);temp=str[i];/*恢復(fù)環(huán)境*/str[i]=str[k];str[k]=temp;組合問題:從自然數(shù)1,2,...,n中任取r個數(shù)的所有組合。解:設(shè)comb(a,m,k)為從1?m中任取k個數(shù)的所有組合(每個組合放在數(shù)組a中)。當(dāng)組合的第1個數(shù)字選定后,其后的數(shù)字是從余下的m-1個數(shù)中取k-1個數(shù)的組合。求解組合問題的遞歸模型如下:comb(a,m,k):輸出產(chǎn)生的解若k=1comb(a,m,k):對于k?m的i,a[k-1]=i;其他情況comb(a,i-1,k-1);對應(yīng)的算法如下:intn,r;/*全局變量*/voidprint(inta[])/*輸出一個組合*/{intj;for(j=r-1;j>=0;j--)printf("%d”,a[j]);printf("\n”)}voidcomb(inta[],intm,intk){inti;for(i=m;i>=k;i--){a[k-1]=i;if(k>1)comb(a,i-1,k-1);elseprint(a);}}Voidmain(){Inta[Maxsize];Printf(“輸入n,r(r<=n):”);Scanf(“%d,%d”,&n,&r);Printf(“輸出結(jié)果:\n”);Comb(a,n,r);prinf("\n”);}棋子移動問題:有2n個棋子(n>=4)排成一行,開始位置為白色全部在左邊,黑色全部在右邊。移動棋子的規(guī)則是:每次必須同時移動相鄰兩個棋子,顏色不限,可以左移也可以右移到空位上去,但不能調(diào)換兩個棋子的左右位置。每次移動必須跳過若干個棋子(不能平移),要求最后能夠移成黑白相間的一行棋子。解:n=4的求解過程下:初始狀態(tài),ooooeeee一一第1步Iooo——???oe第2步:ooo?o??--?第3步]o--????ooe第4步'o?o?o第5步,——o?o?o?o?設(shè)mv(n)表示求解2n個棋子移動的問題,則棋子移動問題求解的遞歸模型如下:mv(n):直接求解mv(n):將c[n]、c[n+1]棋子對移動到c[2n+1]、c[2n+2]處即mv(n);其他情況將c[2n-1]、c[2n]棋子對移動到c[n]、c[n+1]處即mv(2n-1);mv(n-1);對應(yīng)的算法如下:#include<stdio.h>#include<string.h>constintMAX=100;charc[MAX][3];intst=0,sp,n;voidprintf(){printf("step%-2d”,++st);for(inti=1;i<=2*n+2;i++)printf("%s”,c[i]);printf("\n”)}voidmvtosp(intk){for(intj=0;j<=1;j++){strcpy(c[sp+j],c[k+j]);strcpy(c[k+j],”一“}sp=k;print();}voidmv(intn){intist=0sp=2*n+1for(i=1;i<=n;i++)strcpy(c[i],”?!?;for(i=n+1;i<=2*n;i++)strcpy(c
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 單位工程劃分課件
- 華清宮介紹教學(xué)課件
- 廣南一中初小數(shù)學(xué)試卷
- 健康類課件小腳印
- 2025屆青海省海東市高一物理第二學(xué)期期末學(xué)業(yè)質(zhì)量監(jiān)測試題含解析
- 帶鎖起釘器項目投資可行性研究分析報告(2024-2030版)
- 中國蒜頭破碎機(jī)行業(yè)市場前景預(yù)測及投資價值評估分析報告
- 中國無人機(jī)戰(zhàn)爭行業(yè)市場前景預(yù)測及投資價值評估分析報告
- 2025年中國淡菜干行業(yè)市場發(fā)展現(xiàn)狀及投資規(guī)劃建議報告
- 中國甘氨膽酸行業(yè)市場調(diào)查報告
- 2024年寧夏婦女兒童醫(yī)院招聘事業(yè)單位工作人員真題
- 國家開放大學(xué)《藥物治療學(xué)(本)》形考作業(yè)1-4參考答案
- 成都設(shè)計咨詢集團(tuán)有限公司2025年社會公開招聘(19人)筆試參考題庫附帶答案詳解
- 滅火器培訓(xùn)試題及答案
- 女性不孕癥中西醫(yī)結(jié)合診療指南
- 快遞站轉(zhuǎn)讓合同協(xié)議書范本
- 禁止黃賭毒協(xié)議書模板
- 礦泉水銷售合同協(xié)議
- 白酒質(zhì)押貸款合同協(xié)議
- 2025-2030中國大麻煙行業(yè)市場發(fā)展趨勢與前景展望戰(zhàn)略研究報告
- 一年級家長心理輔導(dǎo)課件
評論
0/150
提交評論