Cod sursa(job #165642)

Utilizator portocalaDiculescu Elena Alexandra portocala Data 26 martie 2008 14:25:55
Problema Cel mai lung subsir comun Scor 30
Compilator cpp Status done
Runda Arhiva educationala Marime 0.73 kb
#include<fstream.h>
#define max(x,y) (x)>(y) ? (x):(y)
#define dim 1025
int n,m,a[dim][dim],v[dim],w[dim];
ofstream g("cmlsc.out");

void afisare(int i,int j)
{if((i>0)&&(j>0))
  {if((a[i][j]>a[i-1][j])&&(a[i][j]>a[i][j-1]))
    {afisare(i-1,j-1);
     g<<v[i]<<" ";
    }
   else if(a[i][j]>a[i-1][j]) afisare(i,j-1);
    else if(a[i][j]>a[i][j-1]) afisare(i-1,j);
    else afisare(i-1,j-1);
  }
}

int main()
{ifstream f("cmlsc.in");
int i,j;
f>>n>>m;
for(i=1;i<=n;i++)
 f>>v[i];
for(i=1;i<=m;i++)
 f>>w[i];
f.close();
for(i=1;i<=n;i++)
 for(j=1;j<=m;j++)
  {if(v[i]==w[j])a[i][j]=a[i-1][j-1]+1;
    else a[i][j]=max(a[i-1][j],a[i][j-1]);
  }
g<<a[n][m]<<'\n';
afisare(n,m);
g<<'\n';
g.close();
return 0;
}