求最长子串.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
求最长子串.doc

求最长子串 AAAGGCCCGTTCGG AGGCCCGCTTCG 第一部分:简介 1.1问题描述: Longest Common Substring. The following are some instances. X: xzyzzyx Y: zxyyzxz X:MAEEEVAKLEKHLMLLRQEYVKLQKKLAETEKRCALLAAQANKESSSESFISRLLAIVAD Y:MAEEEVAKLEKHLMLLRQEYVKLQKKLAETEKRCTLLAAQANKENSNESFISRLLAIVAG 1.2 用于验证程序的方法: 我们用以下C++程序来验证程序 int main () { string str1 = xzyzzyx; string str2 = zxyyzxz; LCSub sample1(str1, str2); cout The LCSub of the endl string str1 endl and endl string str2 endl is: endl sample1.GetLCSub() \n\n\n; string str3 = MAEEEVAKLEKHLMLLRQEYVKLQKKLAETEKRCALLAAQANKESSSESFISRLLAIVAD; string str4 = MAEEEVAKLEKHLMLLRQEYVKLQKKLAETEKRCTLLAAQANKENSNESFISRLLAIVAG; LCSub sample2(str3, str4); cout The LCSub of the endl string str3 endl and endl string str4 endl is: endl sample2.GetLCSub() \n\n\n; return 0; } 第二部分:数据结构 首先我们设计一个动态二维数组类,提供长度可动态定义的类静态二维数组的方法。 //动态二维数组 template class T class Matrix { public: Matrix(int row, int col)//构造时必须定义有效的行数和列数 { if (row=0 || col=0) exit(0); ROW = row; COL = col; matrix = new T[row*col]; } ~Matrix() { delete[] matrix; } T GetValue(int m, int n)//相当于Matrix[m][n],注意越界 { if (m0 || m=ROW || n0 || n=COL) exit(0); return matrix[m*COL+n]; } void SetValue(int m, int n, T value)//相当于Matrix[m][n],注意越界 { if (m0 || m=ROW || n0 || n=COL) exit(0); matrix[m*COL+n] = value; } public: T *matrix; int ROW; int COL; }; 类LCSub,通过GetLCSub得到两个串的最长公共子串,其中两个串必须在构造函数时作为参数传入。VALUEtable用于记录中间数据。 class LCSub { public: LCSub(string string1, string string2); ~LCSub(); string GetLCSub();//得到最长公共子串 private: LCSub(); string str1; string str2; Matrixint *VALUEtable; }; 第三部分:算法细则 算法思想:利用类似求LCS的思路,我们很容易设计出最长公共子序列的算法。同样,我们利用一个M*N(M=string1长度+1,N=string2长度+1)大小的表格。考虑到子串字符是连续的,在填表时,我们可以根据以下递归式来填: VALUEtable[i][j]= (1)0 当i=0 或 j=0 (2)VALUEtab

文档评论(0)

gsgtshb + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档