#include <bits/stdc++.h>
using namespace std;
const int N = 1005;
int dp[N][N] = {0};
int n,m;
string s1, s2;
int main() {
cin >> n >> m;
cin >> s1 >> s2;
for(int i = 0;i<n;i++) {
for(int j = 0;j<m;j++) {
if (s1[i] == s2[j]) {
dp[i+1][j+1] = dp[i][j] + 1;
} else {
dp[i+1][j+1] = max(dp[i+1][j],dp[i][j+1]);
}
}
}
cout << dp[n][m] << endl;
return 0;
}
// 64 位输出请用 printf("%lld")

京公网安备 11010502036488号