Cod sursa(job #2007205)

Utilizator codi22FMI Condrea Florin codi22 Data 2 august 2017 11:11:33
Problema Cel mai lung subsir comun Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.92 kb
#include <iostream>
#include <cstdio>
using namespace std;
int n1,n2,V1[1025],V2[1025],M[1025][1025],Sol[1025];
int main()
{
    freopen("cmlsc.in","r",stdin);
    freopen("cmlsc.out","w",stdout);
    cin>>n1>>n2;
    for (int i=1;i<=n1;i++)
    {
        cin>>V1[i];
    }
    for (int i=1;i<=n2;i++)
    {
        cin>>V2[i];
    }
    for (int i=1;i<=n1;i++)
        for (int j=1;j<=n2;j++)
    {
        if (V1[i]==V2[j])
        {
            M[i][j]=M[i-1][j-1]+1;
        }
        else
            M[i][j]=max(M[i-1][j],M[i][j-1]);
    }
    cout<<M[n1][n2]<<'\n';
    int i = n1;
    int j = n2;
    int k = 0;
    int mx = M[n1][n2];
    for (i=n1;i>0;i--)
        for (j=n2;j>0&&i>0;j--)
        {
            if (M[i][j]==mx&&V1[i]==V2[j])
            {
                mx--;
                Sol[k++] = V1[i--];
            }
        }
    k--;
    while (k>=0) cout<<Sol[k--]<<" ";
}