作者热门文章
- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
只是一个关于最长公共(public)子序列算法的快速问题。我已经完成了您需要生成子序列的部分,如下所示:
public int[][] lcsLength(char[] input1, char[] input2) {
int[][] opt = new int[M][N];
for (int i = 1; i < input1.length; i++) {
for (int j = 1; j < input2.length; j++) {
if (input1[i] == input2[j]) {
opt[i][j] = opt[i - 1][j - 1] + 1;
} else {
opt[i][j] = Math.max(opt[i][j - 1], opt[i - 1][j]);
}
}
}
return opt;
}
和 printDiff 函数如下:
private static void printDiff(int[][] opt,String x,String y,int i, int j) {
if(i>0 &&j>0 && x.charAt(i-1)==y.charAt(j-1)){
printDiff(i-1,j-1);
System.out.println(x.charAt(i-1));
}
else{
if(j>0&&(i==0||opt[i][j-1]>=opt[i-1][j])){
printDiff(i-1,j-1);
System.out.println("-"+y.charAt(j-1));
}
else if(i>0&&(j==0|| opt[i][j-1]<=opt[i-1][j])){
printDiff(i-1,j-1);
System.out.println(x.charAt(i-1));
}
}
}
然后如果我将其用作参数:
String input1="ABCDE"
String input2="ACDC"
int i=input1.length()
int j=input2.length()
在使用 lcsLength() 生成 opt 矩阵后,我希望 printdiff 能给我:
ABCDE-
A-CD-C
但我得到:
ABCDE-
ABCD-C
关于我做错了什么的任何想法都会对我有很大帮助
谢谢洛朗
最佳答案
来自 wiki :
function printDiff(C[0..m,0..n], X[1..m], Y[1..n], i, j)
if i > 0 and j > 0 and X[i] = Y[j]
printDiff(C, X, Y, i-1, j-1)
print " " + X[i]
else if j > 0 and (i = 0 or C[i,j-1] ≥ C[i-1,j])
printDiff(C, X, Y, i, j-1)
print "+ " + Y[j]
else if i > 0 and (j = 0 or C[i,j-1] < C[i-1,j])
printDiff(C, X, Y, i-1, j)
print "- " + X[i]
else
print ""
这一行:
else if(i>0&&(j==0|| opt[i][j-1]<=opt[i-1][j])){
应该是:
else if(i>0&&(j==0|| opt[i][j-1]<opt[i-1][j])){
(将 <=
改为 <
)
关于java - 最长公共(public)子序列 printdDiff,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15114220/
只是一个关于最长公共(public)子序列算法的快速问题。我已经完成了您需要生成子序列的部分,如下所示: public int[][] lcsLength(char[] input1, char[]
我是一名优秀的程序员,十分优秀!