코딩테스트/백준

[골5] 9251 - LCS

ShovelingLife 2022. 11. 17. 23:45
#include <iostream>
#include <string>
#include <vector>

using namespace std;

int main()
{
    string str1, str2;
    cin >> str1 >> str2;
    str1 = ' ' + str1;
    str2 = ' ' + str2;
    int n = str1.size(), m = str2.size();
    vector<vector<int>> v(n, vector<int>(m));

    for (int i = 1; i < n; i++)
    {
    	for (int j = 1; j < m; j++)
    	{
            if (str1[i] == str2[j])
                v[i][j] = v[i - 1][j - 1] + 1;

            else
                v[i][j] = max(v[i - 1][j], v[i][j - 1]);            
    	}
    }
    cout << v[n - 1][m - 1];
}