文思的题--输入字符串S3,将在S1中的出现的字符串S2都替换成S3.doc_第1页
文思的题--输入字符串S3,将在S1中的出现的字符串S2都替换成S3.doc_第2页
文思的题--输入字符串S3,将在S1中的出现的字符串S2都替换成S3.doc_第3页
文思的题--输入字符串S3,将在S1中的出现的字符串S2都替换成S3.doc_第4页
文思的题--输入字符串S3,将在S1中的出现的字符串S2都替换成S3.doc_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

文思的题=输入字符串S3,将在S1中的出现的字符串S2都替换成S3在字符串S1查找字符串S2出现次数的函数。功能需求 1) 输入的两个字符串S1和S2。 2)查找S2在字符串S1中出现的次数和位置。3) 输入字符串S3,将在S1中的出现的字符串S2都替换成S3。4) 如果S1中不含有S2,则找出在S2中能被S1包含的所有子字符串,并指出其中长度最大和最小的子字符串用户界面 输入: 程序正常运行后,屏幕上显示一个文字菜单(根据序号选定相应的操作项目),当用户选定操作项目所对应的序号时,根据应用程序的提示信息,从键盘上输入相应的数据。输出: 1) 应用程序正常运行后,要在屏幕上显示一个文字菜单2) 要求用户输入数据时,要给出清晰、明确的提示信息,包括输入的数据内容、格式及结束方式等(提示与参考 输入样例 输出样例) 问题补充2009-04-29 21:04前三步已经解决了,第四步:“如果S1中不含有S2,则找出在S2中能被S1包含的所有子字符串,并指出其中长度最大和最小的子字符串”还没有解决!课程设计答辩要用,时间不多了,很急啊!各位高手帮帮忙啊!字符串匹配问题,到网上,找KMP算法就行了。有现成代码的。提问人的追问 2009-04-24 21:56 我已经把下面两部编出来了,【1) 输入的两个字符串S1和S2。 2)查找S2在字符串S1中出现的次数和位置。】第三步【3) 输入字符串S3,将在S1中的出现的字符串S2都替换成S3。】单独出来也编写出来了,现在就剩下怎样把第三步和前两步合在一起还有第四步目前写不出来,希望你能帮忙一下! 下面1和2步代码:#include #include main() int i=0,j=0,position=0; int occur=0; char s1100,s250,s350; printf(please input three stringsn); printf(S1: n); scanf(%s, s1); printf(s2: n); scanf(%s,s2); printf(s3:n); scanf(%s,s3); while(s1j!=0) if (s1j=s2i)&(s2i!=0) i+; j+; else j+; if (s2i=0) occur+; position=j-i+1; printf(nPositions found at :%d ,position); position=0; i=0; printf(nNumber of occurances: %d.n, occur); 提问人的追问 2009-04-24 22:03 下面是独立出来第三步的代码:有没有办法改写下面代码和1,2步代码合并起来一起运行#include #include main() void replace(char *s1,char *s,char *s2,char *s3); static char s1100=abcefababcdabab; static char s100; replace(s1,s,abc,XYZ); printf(%sn,s); void replace(char *s1,char *s,char *s2,char *s3) char *t0,*x,*y; while(*s1!=0) x=s2; if(*s1=*x) for(t0=s1,x=s2;(*t0=*x&*x!=0);t0+,x+) *s+=*s1+; if(*(x+1)=0) s-=strlen(s2); for(y=s3;*y!=0;) *s+=*y+; else *s+=*s1+; *s=0; 回答人的补充 2009-04-24 23:34 #include#includechar s1100,s2100,s3100;int a100,num;void Input()int i,k,p;char ans100100;int len100;int n,m;int min,mas,minp,masp;printf(请输入s1,s2:n);scanf(%s%s,&s1,&s2);num=0;n=0;for(m=0;s1m!=0;m+);for(i=0;im;i+)if(s20=s1i) p=1;for(k=0;s2k!=0;k+)if(s1k+i=0|s1k+i!=s2k) p=0;break;ansnk=s1k+i;ansnk=0;lenn=k;n+;if(p) anum=i+1;num+;i=i+k-1;if(num=0)min=mas=len0;minp=masp=0;printf(s2中能被s1包含的所有子字符串是:n);for(i=1;ileni) min=leni;minp=i;if(masleni) mas=leni;masp=i;printf(长度最大的是%sn,ansmasp);printf(长度最小的是%sn,ansminp);回答人的补充 2009-04-24 23:34 elseprintf(s2在s1中出现了%d次n,num);printf(在s1的位置分别是:);for(i=0;inum;i+)printf( %d,ai);printf(n);void Output()int i,j,m;printf(请输入s3:n);scanf(%s,&s3);j=0;for(i=0;inum;i+) printf(%d ,ai);printf(n);for(m=0;s2m!=0;m+);for(i=0;s1i!=0;i+)if(jnum&i+1=aj)j+;printf(%s,s3);i=i+m-1;continue;printf(%c,s1i);main()int t;doprintf(1)输入两个字符串s1和s2n);printf(2)输入字符串s3,将在s1中的出现的字符串s2都替换成s3n);printf(0)退出n);printf(请输入:);scanf(%d,&t);if(t=1) Input();if(t=2) Output();printf(n);while(t!=0);提问人的追问 2009-04-29 20:44 呵呵,我现在也能实现了!不过好像你的代码功能会好一点,现在前三步能够实现了,还剩下第四步了到目前为止我都还不能实现,你能不能帮忙一下啊!很急啊!课程设计答辩要用的,时间不多了!帮帮忙啊!#include #include main() void replace(char *s1,char *s,char *s2,char *s3); int count(char *s1,char *s2); char s1100,s250,s350; int occur=0; char s100; printf(please input three stringsn); printf(S1: n); gets(s1); printf(S2: n); gets(s2); printf(S3: n); gets(s3); occur=count(s1,s2);replace(s1,s,s2,s3);printf(%sn,s); printf(nNumber of occurances: %d.n, occur); 提问人的追问 2009-04-29 20:53 void replace(char *s1,char *s,char *s2,char *s3) char *t0,*x,*y; while(*s1!=0) x=s2; if(*s1=*x) for(t0=s1,x=s2;(*t0=*x&*x!=0);t0+,x+) *s+=*s1+; if(*(x+1)=0) s-=strlen(s2); for(y=s3;*y!=0;) *s+=*y+; else *s+=*s1+; *s=0; int count(char *s1,char *s2)int i=0,j=0;int occur=0;int position=0;while(s1j!=0) if(s1j=s2i)&(s2i!=0) i+; j+; else j+; if (s2i=0) occur+; position=j-i+1; printf(nPositions found at :%d n,position); position=0; i=0; return o

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论