算法导论,最长单调递增子序列,实验报告

算法导论,最长单调递增子序列,实验报告

ID:30422893

大小:19.85 KB

页数:14页

时间:2018-12-29

算法导论,最长单调递增子序列,实验报告_第1页
算法导论,最长单调递增子序列,实验报告_第2页
算法导论,最长单调递增子序列,实验报告_第3页
算法导论,最长单调递增子序列,实验报告_第4页
算法导论,最长单调递增子序列,实验报告_第5页
资源描述:

《算法导论,最长单调递增子序列,实验报告》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、为了适应公司新战略的发展,保障停车场安保新项目的正常、顺利开展,特制定安保从业人员的业务技能及个人素质的培训计划算法导论,最长单调递增子序列,实验报告  算法导论学习:最大公共子序列、最大公共子串、最大递增子序列  相关代码:  一、最大公共子序列  1、基本概念  一个给定序列的子序列就是该给定序列中去掉零个或者多个元素的序列。形式化来讲就是:给定一个序列X={x1,x2,……,xm},另外一个序列Z={z1、z2、……,zk},如果存在X的一个严格递增小标序列,使得对所有j=1,2,……k,有xij=zj,则Z是X  的子序列。例如:Z={B,C,D,B}是X={

2、A,B,C,B,D,A,B}的一个子序列,相应的小标为。从定义可以看出子序列直接的元素不一定是相邻的。目的-通过该培训员工可对保安行业有初步了解,并感受到安保行业的发展的巨大潜力,可提升其的专业水平,并确保其在这个行业的安全感。为了适应公司新战略的发展,保障停车场安保新项目的正常、顺利开展,特制定安保从业人员的业务技能及个人素质的培训计划  公共子序列:给定两个序列X和Y,如果Z既是X的一个子序列又是Y的一个子序列,则称序列Z是X和Y的公共子序列。例如:X={A,B,C,B,D,A,B},Y={B,D,C,A,B,A},则序列{B,C,A}是X和Y的一个公共子序列,但

3、不不是最长公共子序列。因为它的长度等于3,而子序列{B,C,A,B}其长度等于4,所以序列{B,C,B,A}才是X和Y的一个最长公共子序列。  最长公共子序列问题描述:给定两个序列X={x1,x2,……,xm}和Y={y1,y2,……yn},求出X和Y的最大长度公共子序列。  2、动态规划解决过程  1)描述一个最长公共子序列  如果序列比较短,可以采用蛮力法枚举出X的所有子序列,然后检查是否是Y的子序列,并记录所发现的最长子序列。如果序列比较长,这种方法需要指数级时间,不切实际。  LCS的最优子结构定理:设X={x1,x2,……,xm}和Y={y1,y2,……,y

4、n}为两个序列,并设Z={z1、z2、……,zk}为X和Y的任意一个LCS,则:  如果xm=yn,那么zk=xm=yn,而且Zk-1是Xm-1和Yn-1的一个LCS。  如果xm≠yn,那么zk≠xm蕴含Z是是Xm-1和Yn的一个LCS。  如果xm≠yn,那么zk≠yn蕴含Z是是Xm和Yn-1的一个LCS。  定理说明两个序列的一个LCS也包含两个序列的前缀的一个LCS,即LCS问题具有最优子结构性质。  2)一个递归解目的-通过该培训员工可对保安行业有初步了解,并感受到安保行业的发展的巨大潜力,可提升其的专业水平,并确保其在这个行业的安全感。为了适应公司新战略的

5、发展,保障停车场安保新项目的正常、顺利开展,特制定安保从业人员的业务技能及个人素质的培训计划  根据LCS的子结构可知,要找序列X和Y的LCS,根据xm与yn是否相等进行判断的,如果xm=yn则产生一个子问题,否则产生两个子问题。设C[i,j]为序列Xi和Yj的一个LCS的长度。如果i=0或者j=0,即一个序列的长度为0,则LCS的长度为0。LCS问题的最优子结构的递归式如下所示:  3)计算LCS的长度  采用动态规划自底向上计算解。书中给出了求解过程LCS_LENGTH,以两个序列为输入。将计算序列的长度保存到一个二维数组C[M][N]中,另外引入一个二维数组B[

6、M][N]用来保存最优解的构造过程。M和N分别表示两个序列的长度。该过程的伪代码如下所示:  1LCS_LENGTH(X,Y)  2m=length(X);  3n=length(Y);  4fori=1tom  5c[i][0]=0;  6forj=1ton  7c[0][j]=0;  8fori=1tom  9forj=1ton  10ifx[i]=y[j]  11thenc[i][j]=c[i-1][j-1]+1;  12b[i][j]='';目的-通过该培训员工可对保安行业有初步了解,并感受到安保行业的发展的巨大潜力,可提升其的专业水平,并确保其在这个行业的

7、安全感。为了适应公司新战略的发展,保障停车场安保新项目的正常、顺利开展,特制定安保从业人员的业务技能及个人素质的培训计划  13elseifc[i-1][j]>=c[i][j-1]  14thenc[i][j]=c[i-1][j];  15b[i][j]='

8、';  16else  17c[i][j]=c[i][j-1];  18b[i][j]='-';  19returncandb  由伪代码可以看出LCS_LENGTH运行时间为O(mn)。  4)构造一个LCS  根据第三步中保存的表b构建一个LCS序列。从b[m][n]开始,当遇到''时,表

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

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

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