Cod sursa(job #557100)

Utilizator devill_08Buli.vlad devill_08 Data 16 martie 2011 14:20:26
Problema Subsir crescator maximal Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.52 kb
#include <stdio.h>
#define nmax 1000002

long a[nmax],n,i,j,m;

int main ()
{
	long l[nmax],poz[nmax];
	freopen("scmax.in","r",stdin);
	freopen("scmax.out","w",stdout);
	scanf("%ld", &n);
	for(i=1;i<=n;i++) scanf("%ld", a[i]);
	l[n]=1;poz[n]=-1; m=n;
	for(i=n-1;i>0;i--)
	{
		l[i]=1; poz[i]=-1;
		for(j=i+1;j<=n;j++)
		{
			if(l[i]<l[j]+1 && a[i]<a[j])
			{
				l[i]=l[j]+1;
				poz[i]=j;
			}
		}
		if(l[i]>l[m]) m=i;
	}
	i=m;
	while(i!=-1)
	{
		printf("%ld", a[i]);
		i=poz[i];
	}
	return 0;
}