动态规划求两个字符串的连续最长公共子序列
2013-12-11 15:37
260 查看
设字符串A的长度为A.length,字符串B的长度为B.length。
Temp[i][j],为状态数组,0<=i<A.length,0=<j<=B.length。
考虑一般情况,如果A[i]==A[j],则Temp[i][j]=Temp[i-1][j-1]+1,
否则Temp[i][j]=0,注:因为求的是连续最长公共字串所以此次为0。
有了状态转移方程,直接写出代码就可以了。
public static int longCommonString(String a, String b) {
char[] chsa = a.toCharArray();
char[] chsb = b.toCharArray();
int na = chsa.length;
int nb = chsb.length;
int[][] t = new int[na][nb];
int max = 0;
for (int i = 0; i < na; i++)
for (int j = 0; j < nb; j++) {
if (i == 0 || j == 0) {
if (chsa[i] == chsb[j])
{
t[i][j] = 1;
if(t[i][j]>max)
max=t[i][j];
}
} else {
if (chsa[i] == chsb[j]) {
t[i][j] = t[i - 1][j - 1] + 1;
if (t[i][j] > max) {
max = t[i][j];
}
}
}
}
return max;
}
Temp[i][j],为状态数组,0<=i<A.length,0=<j<=B.length。
考虑一般情况,如果A[i]==A[j],则Temp[i][j]=Temp[i-1][j-1]+1,
否则Temp[i][j]=0,注:因为求的是连续最长公共字串所以此次为0。
有了状态转移方程,直接写出代码就可以了。
public static int longCommonString(String a, String b) {
char[] chsa = a.toCharArray();
char[] chsb = b.toCharArray();
int na = chsa.length;
int nb = chsb.length;
int[][] t = new int[na][nb];
int max = 0;
for (int i = 0; i < na; i++)
for (int j = 0; j < nb; j++) {
if (i == 0 || j == 0) {
if (chsa[i] == chsb[j])
{
t[i][j] = 1;
if(t[i][j]>max)
max=t[i][j];
}
} else {
if (chsa[i] == chsb[j]) {
t[i][j] = t[i - 1][j - 1] + 1;
if (t[i][j] > max) {
max = t[i][j];
}
}
}
}
return max;
}
相关文章推荐
- 给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的)。 比如两个串为: abcicba abdkscab ab是两个串的子序列,abc也是,abca也是,其中abca是这两个字符
- 求两个字符串的最长公共子序列的长度(动态规划)
- 求两个字符串的最长公共子序列的长度(动态规划)
- 求两个字符串的最长公共子序列的长度(动态规划)
- 用动态规划找到两个字符串的最长公共子序列
- 两个字符串的最长公共子序列(可以不连续)
- c 语言中连续输入两个字符串的问题
- 求两个字符串的最长的连续公共子串和求两个字符串的公共子序列
- 动态规划--3.最长公共子序列LCS和最长公共子字符串
- 【动态规划】LCS算法:求两字符串最大公共字符串(连续)
- 求两个字符串的(连续的)最长公共子串
- 去除一个字符串的开头和结束部分的空格,中间有连续的两个或两个以上的空格,则保留一个空格
- 求两个字符串的最长公共子串,最长公共子序列,编辑距离
- 求两字符串最长公共子序列——动态规划
- 两个字符串的最长连续公共子串
- 《算法导论》动态规划—最长公共子序列(不连续)--c语言实现
- 求两个字符串的最长的连续公共子串
- 求两个字符串的最长的连续公共子串
- 编程之美3.3——类似——两个字符串的最长公共子序列(LCS)
- 用动态规划的方法求解两个字符串的最长公共子串