提交时间:2023-11-25 10:32:24

运行 ID: 112116

#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; }