码迷,mamicode.com
首页 > 其他好文 > 详细

【转】最长公共子序列(LCS),求LCS长度和打印输出LCS

时间:2017-08-16 21:44:08      阅读:155      评论:0      收藏:0      [点我收藏+]

标签:公共子串   jsb   最长公共子串   子序列   print   log   序列   out   理解   

主要参考:

算法导论-----最长公共子序列LCS(动态规划)

其中,理解递推公式之后,要理解代码中的c数组 是怎么变化的(结合下面这个图的过程,过程为:每一行,从左到右)

技术分享

该文章中,打印LCS的过程(C语言,包括递归和非递归版本)也容易看懂。

Java版本可以参考:最长公共子串、最长公共子序列的Java实现与NLP应用

但打印这一部分看得不太懂:

int i = 0, j = 0;
while (i < substringLength1 && j < substringLength2)
{
     if (str1[i] == str2[j])
      {
            System.out.print(str1[i]);
            i++;
            j++;
      }
       else if (opt[i + 1][j] >= opt[i][j + 1])
             i++;
        else
              j++;
}
System.out.println();

不如看上一篇C语言的打印,递归和非递归都很清楚

【转】最长公共子序列(LCS),求LCS长度和打印输出LCS

标签:公共子串   jsb   最长公共子串   子序列   print   log   序列   out   理解   

原文地址:http://www.cnblogs.com/aaronhoo/p/7375545.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!