- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
最长公共子序列(LCS)算法及报告-Read.doc
最长公共子序列 (LCS)算法及报告
一、实验名称
最长公共子序列问题
二、实验目的及要求
所涉及和需要掌握的知识:
1. 最优子结构性质:当问题的最优解包含子问题的最优子结构
2. 为了解决递归的重复调用问题,采用备忘录的方法,
3. 动态规划的基本原理:
在字母表上,分别给出两个长度为n和m的字符串A和B,这里A= … 的子序列是一个形式为 … 的字符串,其中每个都在1和n之间。例如 ={x,y,z},A=zxyxyz,B=xyyzx那么xyy同时是A和B的长度是3的子序列。然而。它不是A和B的最长的公共子序列,因为字符串xyyx也是A和B的公共的子序列。因此A和B的最长公共子序列的长度是4。
最后得到结论:如果i和j都大于0,那么
l 若 = ,L[i,j]=L[i-1,j-1]+1;
l 若 != ,L[I,j]=max{L[i-1,],L[I,j-1]}
三、实验环境
操作系统:WINDOWS 2000
使用软件:VC
使用语言:C语言
四、问题描述及实验内容
假设A=”xyxxzxyzxy”和B=”zxzyyzxxyxxz”,求出A和B的最长公共子序列的长度并输出其中一个最长公共子序列。
最后求得L[n,m]=6和最长子序列为xyxxxz
五、问题分析和算法描述
LCS的算法表示:
输入:字母表上的两个字符串A和B,长度分别为n和m.
输出:A和B的最长公共子序列的长度和其中一个最长子序列。
1. for i=1 to n
2. L[i,0]=0
3. end for
4. for j=0 to m
5. L[0,j]=0
6. end for
7. for i=1 to n
8. for j=1 to m
9. if = then L[i,j]=L[i-1,j-1]+1
10. else L[I,j]=max{L[i-1,],L[I,j-1]}
11. end if
12. end for
13. end for
14. return L[n,m]
LCS的图表示:
假设A=”xyxxzxyzxy”,B=”zxzyyzxxyxxz”
B
z
x
z
y
y
z
x
x
y
x
x
z
0
1
2
3
4
5
6
7
8
9
10
11
12
A
0
0
0
0
0
0
0
0
0
0
0
0
0
0
x
1
0
0
1
1
1
1
1
1
1
1
1
1
1
y
2
0
0
1
1
2
2
2
2
2
2
2
2
2
x
3
0
0
1
1
2
2
2
3
3
3
3
3
3
x
4
0
0
1
1
2
2
2
3
4
4
4
4
4
z
5
0
1
1
2
2
2
3
3
4
4
4
4
5
x
6
0
1
2
2
2
2
3
4
4
4
5
5
5
y
7
0
1
2
2
3
3
3
4
4
5
5
5
5
z
8
0
1
2
3
3
3
4
4
4
5
5
5
6
x
9
0
1
2
3
3
3
4
5
5
5
6
6
6
y
10
0
1
2
3
4
4
4
5
5
6
6
6
6
表(1)
六、实验步骤及实验结果
实验的具体步骤参考附录(源程序清单)。
实验结果:
七、总结
对上面正确结果中的矩阵进行分析:
1. 若i=0或j=0 L[i,j]=0
2. 若i0,j0和 = L[i,j]=L[i-1,j-1]+1
3. 若i0,j0和 != L[I,j]=max{L[i-1,],L[I,j-1]}
根据上述3点可以得到矩阵如上
对上面正确结果中的最长公共子序列进行分析:(走得路线自定义先向上再向左)
用c[6]来存公共子序列的字符。
1. 从L[10,12]出发向上走直到遇到第一个小于L[8,12]的停止,向左走同样直到遇到第一个小于L[8,12]的停止. =z把存入c[5]=z, L[8,12]向左上角跳到 L[7,11]
2. 从L[7,11]出发向上走直到遇到第一个小于L[6,11]的停止,向左走同样直到遇到第一个小于L[6,10]的停止.把 =x存入c[4]=x,L[6,10]向左上角跳到 L[5,9]
3. 从L[5,9]出发向上走直到遇到第一个小于L[4,9]的停止,向左走同样直到遇到第一个小于L
文档评论(0)