Cod sursa(job #3121910)

Utilizator BlaugranasEnal Gemaledin Blaugranas Data 16 aprilie 2023 09:03:32
Problema Cel mai lung subsir comun Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.47 kb
#include<fstream>
using namespace std;
ifstream F("cmlsc.in");
ofstream G("cmlsc.out");
short n,m,a[1025],b[1025],s[1025][1025],i,j,k,c[1025];
int main()
{
    for(F>>n>>m;i<n;F>>a[i++]);
    for(i=0;i<m;F>>b[i++]);
    for(i=1;i<=n;++i)
        for(j=1;j<=m;s[i][j]=max<short>(s[i-1][j-1]+(a[i-1]==b[j-1]),max(s[i-1][j],s[i][j-1])),++j);
    for(;n;a[n-1]==b[m-1]?c[++k]=a[--n],--m:s[n-1][m]<s[n][m-1]?--m:--n);
    for(G<<k<<'\n';k;G<<c[k--]<<' ');
    return 0;
}