版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、3.3 最长公共子序列最长公共子序列n定义:一个给定序列的定义:一个给定序列的子序列子序列是在该序是在该序列中删去若干元素后得到的序列。列中删去若干元素后得到的序列。找出找出A, B, C, D的所有子序列的所有子序列思考:有思考:有n个元素的序列至多有多少个子序个元素的序列至多有多少个子序列?列?2n(包括空)(包括空)说说“至多至多”是因为子序列可能相等(但是因为子序列可能相等(但具有不同下标序列)具有不同下标序列)公共子序列公共子序列n定义:如果序列定义:如果序列Z既是序列既是序列X的子序列又的子序列又是序列是序列Y的子序列,则称的子序列,则称Z是是X和和Y的公的公共子序列。共子序列。n
2、找出找出X = (A, B, C, D, A, B), Y = (B, D, C, A, B, A)的所有公共子序列。的所有公共子序列。最长公共子序列最长公共子序列n找出找出X和和Y的最长公共子序列。的最长公共子序列。n对于任意给定的对于任意给定的X和和Y,它们的最长公共,它们的最长公共子序列唯一吗?举例说明。子序列唯一吗?举例说明。n不一定。如不一定。如A, B与与B, An本节的问题是只找出一个最长公共子序本节的问题是只找出一个最长公共子序列。列。最长公共子序列的结构最长公共子序列的结构设序列设序列X=x1, x2, , xm, Y=y1, y2, , yn, Z=z1, z2, , zk
3、,则则(1) 若若xm = yn, 则则Zk - 1 是是Xm 1和和Yn 1的的最长公共子序列;最长公共子序列;如:如:X = , C, Y = , C, 则则Z = , C最长公共子序列的结构最长公共子序列的结构(续续)(2)若若xm yn, 且且zk xm,则,则Z是是Xm 1和和Y的最长公共子序列;的最长公共子序列;如:如:X = , C, Y = , B, zk C, 则则在计算最长公共子序列时,可不考虑在计算最长公共子序列时,可不考虑X的最后一个元素的最后一个元素C最长公共子序列的结构最长公共子序列的结构(续续)(3)若若xm yn, 且且zk yn,则,则Z是是X和和Yn 1的最
4、长公共子序列的最长公共子序列如:如:X = , C, Y = , B, zk B, 则则在计算最长公共子序列时,可不考在计算最长公共子序列时,可不考虑虑Y的最后一个元素的最后一个元素B最长公共子序列的结构最长公共子序列的结构(续续)n两个序列的最长公共子序列包含了两个序列的最长公共子序列包含了这两个序列的前缀的最长公共子序这两个序列的前缀的最长公共子序列,因此,最长公共子序列问题具列,因此,最长公共子序列问题具有最优子结构性质。有最优子结构性质。讨论讨论可否根据序列的第可否根据序列的第1个元素来重述本问个元素来重述本问题?这样做有什么优缺点?题?这样做有什么优缺点?可以。这样做不利于描述,如前
5、面可以。这样做不利于描述,如前面Xm1可以方便地表示可以方便地表示X前前m 1 个元素,改个元素,改后就比较麻烦。从递归的角度来看,后就比较麻烦。从递归的角度来看,一般也是从后面增减元素。一般也是从后面增减元素。n当当xm = yn时,有一个子问题,即时,有一个子问题,即 :找出:找出Xm 1和和Yn 1的最长公共子序列的最长公共子序列n当当xm yn时,有两个子问题,即时,有两个子问题,即 (1)找出找出Xm 1和和Y的最长公共子序列,的最长公共子序列, (2)找出找出X和和Yn 1的的最长公共子序列。而这两个子问题都包含了最长公共子序列。而这两个子问题都包含了同一个子问题同一个子问题(Xm
6、 1, Yn1) 。 因此,本问题因此,本问题满足子问题重叠性质。满足子问题重叠性质。问题分析问题分析令令cij记录记录Xi和和Yj的最长公共子序列的长度,的最长公共子序列的长度,则有则有 0 i = 0, j = 0cij = ci - 1j - 1 + 1 xi = yj maxcij - 1 , ci - 1j xi yj问题分析问题分析(续续)n显然不应以递归方式(自顶向下,即先考虑显然不应以递归方式(自顶向下,即先考虑最后一个字符)设计算法,而应设计动态规最后一个字符)设计算法,而应设计动态规划算法,即从第一个字符开始考虑。划算法,即从第一个字符开始考虑。问题分析问题分析(续续)计算
7、最优值计算最优值程序跟踪程序跟踪X = A C B D Y = A B D A c b00000011110111101222012330000001331022220213302213ijxi=yj ci-1j=cij-111Y2N3N4Y21NY2NY补充习题补充习题n1. X=B, C, A, D Y=C, A, B, D,求X与Y的最长公共子序列,并画出数组c与b. c b00000000110111101222012230000002213013220213302221i:j:补充习题补充习题(答案答案)n1. X=B, C, A, D Y=C, A, B, D,求X与Y的最长公共子序列,并画出数组c与b. c b00000000110111101222012230000002213013220213302221i: 1 2 3j: 1 2 3 4 1 2 3 4 1 2 3 4讨论讨论结构化与面向对象程序设计的联系与区别?结构化与面向对象程序设计的联系与区别?面向对象的局部来看是结构化的。面向对象的局部来看是结构化的。结构化的基本思想是结构化的基本思想是“自顶向下,逐步求精自顶向下,逐步求精”,面向对象的基本意图是提高软件模块的面向对象的基本意图是提高软件模块的复用性
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论