数据结构求最大公共子串

数据结构求最大公共子串

ID:22287538

大小:105.25 KB

页数:7页

时间:2018-10-28

数据结构求最大公共子串_第1页
数据结构求最大公共子串_第2页
数据结构求最大公共子串_第3页
数据结构求最大公共子串_第4页
数据结构求最大公共子串_第5页
资源描述:

《数据结构求最大公共子串》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、数据结构课程设计2014-2015年第一学期院系:计算机科学与技术业:软件工程题:求最大公共子串年级班:姓名:学号:成绩:指导教师:王爱平2014.10.8目录1课程设计的目的32需求分析33课程设计报告内容33.1概要设计33.2详细设计33.4调试分析53.5用户手册53.6测试结果63.7程序清单64吉75参考文献71.课程设计的目的(1)熟练使用C语言编写程序,解决实际问题;(2)了解并掌握数据结构与算法的设计方法,具备初步的独立分析和设计能力;(3)初步掌握软件开发过程的问题分析、系统设计、程序编码、测试等基本方法和技能;(4)提高综合运用所学的理论知识和方法独立分析

2、和解决问题的能力;2需求分析以顺序存储结构存储串,求两个字符串的最大的公共子串,约束字符的最大长度是256,同时如果没有的公共的,也会出现提示信息。公共子串指的是字符串U如果既是字符串S的子串又是字符串T的子串,则字符串U是字符串S和T的一个公共子串。最长公共子串:字符串S和T的最长公共子串是指字符串S和T的所有公共后缀中长度最大的后缀。例如:给定3个长度分别为4,4的字符串“abab”,“baba”,它们的公共子串有“”,“a”,“b”,“ab”,“ba”,“aba”,“bab”。其中最长公共子串(LCS)即为“aba”或“bab”。3概要设计3.1主界面的设计3.2存储结构

3、设计顺序存储结构表示串3.3详细设计(1)voidsearch(SStringM,SStringP)//匹配函数{(2)voidmain()3.3.1程序运行的流程图各个函数之间的调用关系Voidmain()Voidsearch()程序运行的流程图:幵始3.3.2运行截图gyuijnbferjkigyuwsazx10ii第二*^

4、为:gyuijnbfer,长爲^串为:jkigyuwsazx,公共子串最大长:度为:3,最长:公共子串为:gyu请按任意键继续•••-WSAg—:gyuiktrop请输入弟二个孛捋卓=00000第一个串为:gyuiktrop,长度:9第二个卓为:000

5、00,长度:S您输入的两个字符串无公共子串!请按任意键继续..•-3.4调试分析调试的时候,对串的匹配的开始没有弄懂,导致在调试的时候出现了错误。后来自己琢磨以及手工的演算是调试成功。3.5用户手册3.4.1本程序执行文件为“最大公共子串.exe。”3.4.2在进入本系统的主界面后,按照提示输入第一个字符串和第二个字符串3.4.3字符串的最大个数数2563.6测试结果结果运行成功3.7程序清单#include#include#incIude#defineMax256typedefstruct{charch[Max];in

6、tlength;}SString;voidsearch(SStringM,SStringP)//匹配函数{inti,j,k,a,c;intb=1;intm二P.length;intn=M.length;intindex=0;//第一个匹配项intmaxlen=0;//最大的匹配长度intflag;for(i=0;i<=n;i++)k=i;for(j=0;j<=m;j++)a=0;whilech[k]==P.ch[j])k++;j++;a++;flag二1;}if(flag::1){if(a>maxIen){maxlen=a;index二j-a;//匹配的首项})}}if(max

7、len!=O){maxIen);printf("公共子串最大长度为:%d,最长公共子串为:for(;maxIen>0;maxIen——)printf("%c",P.ch[index++]);)printf(nn):}elseprintf("您输入的两个字符串无公共子串!n);)voidmain(){SStringM1,P1;system("cIs");printf("请输入第一个字符串:");gets(M1.ch);printf("请输入第二个字符串:");gets(P1.ch);M1.Iength^strIen(M1.ch);P1.Iength^str

8、Ien(P1.ch);printf("");printf("第一个串为:%s,长度:%d",M1.ch,M1.length)printf("第二个串为:%s,长度:%d",P1.ch,P1.length);search(M1,P1);system("pause"):}4小结在这次的赶作业的过程中,体会到了要多动手,要注意理论与实际的结合,对平时的知识要求掌握熟练,这样在编程的时候可以快速的实现自己的想法,提高自己完成作业的速度。多注意对资料的查阅,这样能够掌握一些自己不太熟悉的东

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。