Pagini recente » Cod sursa (job #3280314) | Cod sursa (job #3137895) | Cod sursa (job #2310515) | Cod sursa (job #1579581) | Cod sursa (job #145667)
Cod sursa(job #145667)
#include<stdio.h>
#define Nmax 1026
int A[Nmax], B[Nmax], C[Nmax][Nmax];
int sol[Nmax];
int MAX(int x,int y){
if(x>y)
return x;
return y;
}
int main(){
FILE *fin = fopen("cmlsc.in","r"),
*fout = fopen("cmlsc.out","w");
int N,M;
fscanf(fin,"%d%d",&N,&M);
for(int i=1;i<=N;i++)
fscanf(fin,"%d",&A[i]);
for(int i=1;i<=M;i++)
fscanf(fin,"%d",&B[i]);
for(int i=1;i<=N;i++)
for(int j=1;j<=M;j++){
C[i][j] = MAX(C[i-1][j], C[i][j-1]);
if(A[i] == B[j])
C[i][j] = MAX(C[i][j], C[i-1][j-1] + 1);
}
int poz = C[N][M];
int limi = N, limj = M;
while(poz){
int ok = 1;
for(int i=limi;i && ok;i--)
for(int j=limj;j && ok;j--)
if(A[i] == B[j] && C[i][j] == C[i-1][j-1] + 1 && C[i][j] == poz){
sol[poz] = A[i];
poz--;
limi = i-1;
limj = j-1;
ok = 0;
}
}
fprintf(fout,"%d\n",C[N][M]);
for(int i=1;i<=C[N][M];i++)
fprintf(fout,"%d ",sol[i]);
fclose(fin);
fclose(fout);
return 0;
}