Files
Data-Structure/Algorithm/DP-DynamicProgramming/Linear-DP/P1439.cpp
2025-09-15 22:16:09 +08:00

29 lines
581 B
C++

#include <iostream>
#include <vector>
using namespace std;
int main(){
int n;
cin >> n;
vector<int> a(n), b(n);
for(int i = 0; i < n; i++){
cin >> a[i];
}
for(int i = 0; i < n; i++){
cin >> b[i];
}
int a_size = a.size(), b_size = b.size();
vector<vector<int>> dp(a.size() + 1, vector<int>(b_size + 1, 0));
for(int i = 1; i <= a_size; i++){
for(int j = 1; j <= b_size; 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]);
}
}
}
cout << dp[a_size][b_size] << endl;
return 0;
}