Cod sursa(job #690458)

Utilizator ivonaChili Ivona Alexandra ivona Data 25 februarie 2012 17:22:45
Problema Subsir crescator maximal Scor 70
Compilator cpp Status done
Runda Arhiva educationala Marime 0.57 kb
#include<stdio.h>
FILE *f=fopen("scmax.in","r");
FILE *g=fopen("scmax.out","w");
int i,n,v[100001],l[100001],poz[100001],p,max,j,k=0,fin[100001],k1=0;
int main()
{
	
	fscanf(f,"%d",&n);
	for(i=1;i<=n;i++)fscanf(f,"%d",&v[i]);
	for (i=1;i<=n;i++) l[i]=1;
	poz[n]=0;
	for(i=n-1;i>=1;i--)
	{
		max=0;
		p=0;
		for(j=i+1;j<=n;j++)
		{
			if(v[i]<v[j]&&l[j]>max){max=l[j];p=j;}
		}
		l[i]=max+1;
		poz[i]=p;
		
	}
	max=0;
	for(i=1;i<=n;i++)
	{
		if(l[i]>max){max=l[i];p=i;}
	}
	fprintf(g,"%d\n",max);
	while(p>0)
	{
		fprintf(g,"%d ",v[p]);
		p=poz[p];
	}
}