10405 - Longest Common Subsequence
28 Jan 2021 — Tags: None
Click to show code.
using namespace std;
using vi = vector<int>;
int solve(string s, string t)
{
int n = (int)s.size(), m = (int)t.size();
vector<vi> dp(n + 1, vi(m + 1, 0));
for (int i = 1; i <= n; ++i)
{
for (int j = 1; j <= m; ++j)
{
auto &ans = dp[i][j];
ans = max(ans, dp[i - 1][j]);
ans = max(ans, dp[i][j - 1]);
if (s[i - 1] == t[j - 1])
ans = max(ans, dp[i - 1][j - 1] + 1);
}
}
return dp[n][m];
}
int main(void)
{
ios::sync_with_stdio(false), cin.tie(NULL);
string s, t;
while (getline(cin, s) and getline(cin, t))
{
cout << solve(s, t) << endl;
}
return 0;
}