int findLCS(string A, int n, string B, int m) {// 最長公共子序列
string strA = "#" + A;
string strB = "#" + B;
int C[n+1][m+1];
for(int i=0; i <= n; i++)
C[i][0] = 0;
for(int i=0; i <= m; i++)
C[0][i] = 0;
for(int i=1; i <= n; i++) {
for(int j=1; j <= m; j++) {
if(strA[i] == strB[j])
C[i][j] = C[i-1][j-1] + 1;
else if(C[i-1][j] > C[i][j-1])
C[i][j] = C[i-1][j];
else
C[i][j] = C[i][j-1];
}
}
return C[n][m];
}
int findLongest(string A, int n, string B, int m) {// 最長連續公共子序列
string strA = "#" + A;
string strB = "#" + B;
int C[n+1][m+1];
for(int i=0; i <= n; i++)
C[i][0] = 0;
for(int i=0; i <= m; i++)
C[0][i] = 0;
int maxL = -1;
for(int i=1; i <= n; i++) {
for(int j=1; j <= m; j++) {
if(strA[i] == strB[j])
C[i][j] = C[i-1][j-1] + 1;
else
C[i][j] = 0;
if(C[i][j] > maxL)
maxL = C[i][j];
}
}
return maxL;
}
最長公共子序列VS最長連續公共子序列
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.