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

动态规划-最长公共子序列(LCS)

时间:2021-01-01 12:21:19      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:new   mat   math   ati   har   ble   mamicode   print   man   

问题

求两个字符串的 LCS ?度:

?: str1 = "abcde", str2 = "ace"

输出: 3

解释: ?公共?序列是 "ace",它的?度是 3

思路

对于两个字符串的动态规划问题,?般来说都是定义 DP table,容易写出状态转移?程, dp[i][j] 的状态可以通过之前的状态推导出来:

技术图片

《算法导论》中关系式如下 :

技术图片

这里的c[i][j] 就是 DP table ;

代码实现

public static void main(String[] args) {

String s1 = "abcde";

String s2 = "ace";

int len = lcsLength(s1, s2);

System.out.println("lcs长度:" + len);

}

 

public static int lcsLength(String s1, String s2) {

int m = s1.length();

int n = s2.length();

//dp[x][0]dp[0][x]=0

int dp[][] = new int[m + 1][n + 1];

 

int count = 0;

//注意,这里 i,j 是从1 开始, 而字符串应该从0开始...

for (int i = 1; i <= m; i++) {

for (int j = 1; j <= n; j++) {

if (s1.charAt(i - 1) == s2.charAt(j - 1)) {

dp[i][j] = dp[i - 1][j - 1] + 1;

} else {

dp[i][j] = Math.max(dp[i][j - 1], dp[i - 1][j]);

}

count++;

}

}

System.out.println("循环总次数:" + count);

return dp[m][n];

}

动态规划-最长公共子序列(LCS)

标签:new   mat   math   ati   har   ble   mamicode   print   man   

原文地址:https://www.cnblogs.com/coloz/p/14199969.html

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