#include<iostream>
#include<string.h>
int count=0;
using namespace std;
int max(int a,int b)
{
return (a>b)?a:b;
}
int lcs(char *x,char*y ,int m,int n)
{
int l[m+1][n+1];
int i,j;
for( i=0;i<=m;i++)
{
for(j=0;j<=n;j++)
{
if(i==0 || j==0)
l[i][j]=0;
else if(x[i-1]==y[j-1])
l[i][j]=l[i-1][j-1]+1;
else
l[i][j] =max(l[i-1][j], l[i][j-1]);
}
}
return l[m][n];
}
int main()
{
char x[]="AGGTAB";
char y[]="GXTXAYB";
int m=strlen(x);
int n=strlen(y);
cout<<"The Length Of the Longest Common Subsequence Is : "<<lcs(x,y,m,n);
}
上述程序用于使用动态规划找到最大公共子序列解决方案。我能够计算 LCS 的长度,但我无法推断找到总数的逻辑。系统将进行比较以找到 lcs 。
我想找到总数。比较并使用全局计数变量打印它。有人可以帮我吗?