Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
112116 | 毛泓博(做题专用,大号Fess) | 最长公共子序列 | C++ | 运行出错 | 0 | 0 MS | 92 KB | 390 | 2023-11-25 10:32:24 |
#include<bits/stdc++.h> using namespace std; string a,b; int dp[10000][10000],sa,sb; int f(void) { sa=a.length(); sb=b.length(); for(int i=1;i<=sa;i++) { for(int j=1;j<=sb;j++) { if(a[i-1]==b[j-1]) dp[i][j]=dp[i-1][j-1]+1; else dp[i][j]=max(dp[i-1][j],dp[i][j-1]); } } return dp[sa][sb]; } int main() { while(cin>>a>>b) cout<<f()<<endl; return 0; }