下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
算法设计题(每题10分,共30分)【严题集4.12③】编写一个实现串的置换操作Replace(&S,T,V)的算法。解:intReplace(Stringtype&S,StringtypeT,StringtypeV);/将串S中所有子串T替换为V,并返回置换次数{for(n=0,i=1;i<=Strlen(S)-Strlen(T)+1;i++)雄意i的取值范围if(!StrCompare(SubString(S,i,Strlen(T)),T))/找到了与T匹配的子串{〃分别把T的前面和后面部分保存为head和tailStrAssign(head,SubString(S,1,i-1));StrAssign(tail,SubString(S,i+Strlen(T),Strlen(S)-i-Strlen(T)+1));StrAssign(S,Concat(head,V));StrAssign(S,Concat(S,tail));//把head,V,tail连接为新串i+=Strlen(V);//当前指针跳到插入串以后n++;n++;}//ifreturnn;}//Replace分析:i+=Strlen(V);这一句是必需的,也是容易忽略的.如省掉这一句,则在某些情况下,会引起不希望的后果,虽然在大多数情况下没有影响.请思考:设S='place',T='ace',V='face',则省掉i+=Strlen(V);运行时会出现什么结果?【全国专升本资格考试】写出将字符串反序的递归或递推算法,例如字符串为“abcsxw”,反序为“wxscba”(注:这也是严题集4.10③编写对串求逆的递推算法)请注意递归和递推的区别!递推是由“小”到“大”递进;递归是由“大”到“小”嵌套。算法思路:①假定用单链表结构存储字符串;if没有到尾部字符就不停调用自身函数,直至到达末尾,再从尾部返回并打印字符;递归算法的一般形式:(殷人凯题集P102递归算法的一般形式:(殷人凯题集P102)voidp(参数表){if(递归结束条件)可直接求解步骤; 基本项elsep(较小的参数); 归纳项}Invert(stringlistnode*p){if(!p)return(0);elseInvert(p->next);printf("%c”>data)}如果当前串长为0,则return(-1)否则开始递归:if串没有到末尾,则P=P->next;再调用invert(s);elseprintf(p->data);return严题集4.10③答案:voidString_Reverse(Stringtypes,Stringtype&r)//求s的逆串rStrAssign(r,'');/初始化r为空串for(i=Strlen(s);i;i--){StrAssign(c,SubString(s,i,1));StrAssign(r,Concat(r,c));/把s的字符从后往前添加到r中 /这是递推算法。}}//String_Reverse3.【严题集5.18⑤】试设计一个算法,将数组An中的元素A[0]至A[n-1]循环右移k位,并要求只用一个元素大小的附加存储,元素移动或交换次数为O(n)解:分析:要把A的元素循环右移k位,则A[0]移至A[k],A[k]移至A[2k]......直到最终回到A[0],然而这并没有全部解决问题,因为有可能有的元素在此过程中始终没有被访问过,而是被跳了过去.分析可知,当n和k的最大公约数为p时,只要分别以A[0],A[1],...A[p-1]为起点执行上述算法,就可以保证每一个元素都被且仅被右移一次,从而满足题目要求,也就是说,A的所有元素分别处在p个"循环链"上面,举例如下:n=15,k=6,则p=3.第一条链:A[0]->A[6],A[6]->A[12],A[12]->A[3],A[3]->A[9],A[9]->A[0]./已“顺便”移动了A[6]、A[12]…第二条链:A[1]->A[7],A[7]->A[13],A[13]->A[4],A[4]->A[10],A[10]->A[1].第三条链:A[2]->A[8],A[8]->A[14],A[14]->A[5],A[5]->A[11],A[11]->A[2].恰好使所有元素都右移一次.虽然未经数学证明,但作者相信上述规律应该是正确的.程序如下:voidRSh(intA[n],intk)//把数组A的元素循环右移k位,只用一个辅助存储空间{for(i=1;i<=k;i++)if(n%i==0&&k%i==0)p=i;//求n和k的最大公约数pfor(i=0;i<p;i++){j=i;l=(i+k)%n;temp=A[i];while(l!=i){A[j]=temp;temp=A[l];A[l]=A[j];j=l;l=(j+k)%n;}//循环右移一步A[i]=temp;}//for}//RSh附加题:利用C的库函数strlen,strcpy(或strncpy)写一个算法voidStrDelete(char*S,intt,intm),删除串S中从位置i开始的连续的m个字符。若iNstrlen(S),则没有字符被删除;若i+mNstrlen(S),则将S中从位置i开始直至末尾的字符均被删去。提示:strlen是求串长(length)函数:i
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 统编人教版六年级语文上册第11课《宇宙生命之谜》精美课件
- 2024版设备销售与服务合同2篇
- 花卉苗木购销合同简单版
- 秸秆打包合同
- 公寓合作协议签订合同范本版
- 2024版钢筋混凝土工程保修合同2篇
- 2024年度钢结构行业市场调查与分析合同
- 2024版特许经营合同终止协议2篇
- 2024年度大数据技术与应用合同
- 高档合同书图片
- 2024-2030年全球及中国乳清蛋白水解物行业供需现状及前景动态预测报告
- 2024-2030年中国铝合金板行业供需现状分析及投资战略研究报告版
- 2024年黑龙江省齐齐哈尔市中考语文试卷
- 2024年化妆品ODM合作合同
- 预防电信诈骗打击网络犯罪49
- 少年的风采 课件 2024-2025学年湘美版(2024)初中美术七年级上册
- 班主任培训课件
- 石油化工代加工合同模板
- 第03讲 鉴赏诗歌的表达技巧(课件)-2025年高考语文一轮复习讲练测(新教材新高考)
- 污水处理厂土建工程的主要施工方案
- 集体生活成就我 课件-统编版道德与法治七年级上册
评论
0/150
提交评论