Cod sursa(job #522850)

Utilizator RengelBotocan Bogdan Rengel Data 16 ianuarie 2011 13:53:21
Problema Subsir crescator maximal Scor 70
Compilator cpp Status done
Runda Arhiva educationala Marime 0.59 kb
#include<cstdio>

FILE *fin=fopen("scmax.in","r");
FILE *fout=fopen("scmax.out","w");

int a[100001],sln[100001],n,i,max,j,maxim,poz;

int main(){
	
	fscanf(fin,"%d",&n);
	
	for(i=1;i<=n;i++)
		fscanf(fin,"%d",&a[i]);
	
	sln[n]=1;
	
	
	for(i=n-1;i>=1;i--){
		max=0;
		for(j=i+1;j<=n;j++)
			if(a[i]<a[j] && sln[j]>max)
				max=sln[j];
		sln[i]=max+1;
		if(sln[i]>maxim){
			maxim=sln[i];
			poz=i;
		}
	}
	
	fprintf(fout,"%d\n%d",maxim,a[poz]);
	
	maxim--;
	for(i=poz+1;i<=n;i++){
		if(sln[i]==maxim){
			fprintf(fout," %d",a[i]);
			maxim--;
		}
	}
	
	return 0;
	
}