51nod 最长公共子序列问题(动态规划)(LCS)(递归)
最长公共子序列问题
输入
第1行:字符串A 第2行:字符串B (A,B的长度 <= 1000)
输出
输出最长的子序列,如果有多个,随意输出1个。
输入示例
abcicba abdkscab
输出示例
abca
请选取你熟悉的语言,并在下面的代码框中完成你的程序,注意数据范围,最终结果会造成Int32溢出,这样会输出错误的答案。
不同语言如何处理输入输出,请查看下面的语言说明。
#include <iostream> #include <cstring> #include <cstdio> #include <cstring> #include <algorithm> #include <cmath> #include <time.h> #include <string> #include <map> #include <stack> #include <vector> #include <set> #include <queue> #define inf 0x3f3f3f3f #define mod 1000000007 typedef long long ll; using namespace std; char a[1005]; char b[1005]; int dp[1005][1005]; int pre[1005][1005]; void dfs(int m,int n) { if(m==0||n==0) return; if(pre[m][n]==1) { dfs(m-1,n-1); cout<<a[m]; } else if(pre[m][n]==2) { dfs(m-1,n); } else { dfs(m,n-1); } } int main() { int i,j,len1,len2; memset(dp,0,sizeof(dp)); memset(pre,0,sizeof(pre)); cin>>a+1>>b+1; len1=strlen(a+1); len2=strlen(b+1); for(i=1;i<=len1;i++) { for(j=1;j<=len2;j++) { if(a[i]==b[j]) { dp[i][j]=dp[i-1][j-1]+1; pre[i][j]=1; } else { if(dp[i-1][j]>dp[i][j-1]) { dp[i][j]=dp[i-1][j]; pre[i][j]=2; } else { dp[i][j]=dp[i][j-1]; pre[i][j]=3; } } } } dfs(len1,len2); cout<<endl; return 0; }