下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
6.4补考练习题及参考答案6.4.1单项选择题1.递归函数f(n)=f(n-1)+n(n>1)的递归出口是A.f⑴=1B.f⑴=0C.f(0)=0D.f(n)=n答:当n=0时,f⑴=0。本题答案为B。2.递归函数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.将递归算法转换成对应的非递归算法时,通常需要使用保存中间结果。A.队列B.栈C.链表D.树答:递归计算过程是:先进行递归分解,知道递归出口为止,然后根据递归出口的结果反过来求值。这样通常需要后面的递推式先计算出结果,这正好满足栈的特点。所以本题答案为B。6.4.2填空题1.将h,转化成递归函数,其递归出口是―①,递归体是―②—答:①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”);}}调用语句print(4)的结果是。答:1223334444有如下递归过程:voidreverse(intm){printf("%d”,n%100);if(n/10!=0)reverse(n/10);}调用语句reverse(582)的结果是。答:reverse()函数将给定的参数逆转。本题答案为:285.6.4.3判断题判断以下叙述的正确性。任何递归算法都有递归出口。递归算法的执行效率比功能相同的非递归算法的执行效率高。递归算法不能转换成对应的非递归算法。答:(1)正确。错误。通常情况下递归算法的执行效率比功能相同的非递归算法的执行效率低。错误。可以用栈将递归算法转换成对应的非递归算法。6.4.3简答题设a是含有n个元素的整数数组。写出求n个整数之和的递归定义。写出求n个整数之积的递归定义。答:假定数组a的下标从0开始。设f(a,i)返回a[0]〜a[i-1]元素之和。当i=1,f(a,1)=a[0];假设数组a的前i-1个元素之和已经求出,即已知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个整数之和=f(a,n)。设f(a,i)返回a[0]〜a[i-1]元素之积。当i=1,f(a,1)=a[0];假设数组a的前i-1个元素之积已经求出,即已知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个整数之积=f(a,n)。以下算法是计算两个正整数u和v最大公因数的递归函数,给出其递归模型。intgcd(intu,intv){intr;if((r=u%v)==0)return(v);elsereturn(gcd(u,r));}答:由上述函数得到如下递归模型如下:gcd(u,v)=v当u%v=0时gcd(u,v)=gcd(u,u%v)其他情况6.4.4算法设计题编写一个递归过程,它读入一串任意长的字符串,该串字符以“.”作为结束,要求打印出它们的倒序字符串。解:首先获取用户按键,如果不是.字符,则递归调用该过程,否则显示该字符。对应的算法如下:voidreverse()charch;scanf("%c”,&ch);if(ch!=‘.’){reverse();printf("%c”,ch);}}全排列问题:输An个不同的字符,给出它们所有的n个字符的全排列。解:将n个不同的字符存放在字符串str中,求解全排列问题的递归模型如下:perm(str,k,n):输出产生的解若k=n-1perm(str,k,n):对于k〜n-1的i,str[i]与str[k]交换位置;其他情况perm(str,k+1,n);将str[k]与str[i]交换位置;/*回复环境*/对应的算法如下: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];/*恢复环境*/str[i]=str[k];str[k]=temp;组合问题:从自然数1,2,...,n中任取r个数的所有组合。解:设comb(a,m,k)为从1〜m中任取k个数的所有组合(每个组合放在数组a中)。当组合的第1个数字选定后,其后的数字是从余下的m-1个数中取k-1个数的组合。求解组合问题的递归模型如下:comb(a,m,k):输出产生的解若k=1comb(a,m,k):对于k〜m的i,a[k-1]=i;其他情况comb(a,i-1,k-1);对应的算法如下: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(“输出结果:\n”);Comb(a,n,r);prinf("\n”);}棋子移动问题:有2n个棋子(n>=4)排成一行,开始位置为白色全部在左边,黑色全部在右边。移动棋子的规则是:每次必须同时移动相邻两个棋子,颜色不限,可以左移也可以右移到空位上去,但不能调换两个棋子的左右位置。每次移动必须跳过若干个棋子(不能平移),要求最后能够移成黑白相间的一行棋子。解:n=4的求解过程下:初始状态,ooooeeee一一第1步Iooo——•••oe第2步:ooo»o««--•第3步]o--•◦••ooe第4步'o・o・o第5步,——o・o・o・o・设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);对应的算法如下:#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. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 中班语言活动不浪费水
- 新生儿过敏知识培训
- 江西省宜春市丰城市第九中学2024-2025学年八年级上学期第一次段考化学试卷(含解析)
- 甘肃省会宁县第四中学2024-2025学年高三上学期第一次月考化学试卷
- 全球无人机探测与防控系统市场运营现状及发展策略研究报告2024-2030年
- 初中七年级生物上学期期中考前测试卷(人教版)含答案解析
- T-YNRZ 019-2024 珠芽黄魔芋组培种苗生产技术规程
- 内蒙古自治区通辽市科尔沁左翼中旗联盟校2024-2025学年六年级上学期期中考试英语试题
- 【课件】Unit+3+SectionB+1a-2b+课件人教版英语七年级上册
- 高中语文11琵琶行并序锦瑟课件苏教版必修
- 医疗设备定价政策
- 初中英语英语音标教学课件
- 急性皮肤衰竭与压力性损伤鉴别
- 2024生态环境监测技术人员持证上岗考核理论试题库-上(单选题)
- JBT 10704-2023 建筑施工机械与设备 混凝土布料机 (正式版)
- DZ∕T 0283-2015 地面沉降调查与监测规范(正式版)
- 肾内科相关专业知识:肾内科测试题(题库版)
- 三年级上册科学第三单元《家庭用电》知识梳理
- 民族民间体育知到智慧树网课答案
- 项目实施方案及实施计划(2篇)
- 2024年医院见习护士聘用合同(二篇)
评论
0/150
提交评论