Cod sursa(job #720378)

Utilizator hiticas_abelhiticasabel hiticas_abel Data 22 martie 2012 16:52:20
Problema Subsir crescator maximal Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.88 kb
#include<iostream>
#include<stdio.h>
using namespace std;
long a[100001],poz[100001],l[100001],n,i,j,pozmax,a_de_i;
int main()
{
      freopen ("scmax.in","r",stdin);
      freopen ("scmax.out","w",stdout);
       long max=-int(2e9);
          scanf("%ld",&n);

        for(i=1;i<=n;i++)

           scanf("%ld ",&a[i]);
            
               
           l[n]=1;poz[n]=-1;
           for(i=n-1;i--;)
           {
                              a_de_i=a[i];
             l[i]=1;
             poz[i]=-1;
            for(j=i+1;j<=n;j++)
              if(a_de_i<a[j] &&l[i]<1+l[j])
                 {l[i]=l[j]+1;poz[i]=j; }
          
          if(l[i]>max)
          {
           max=l[i];
            pozmax=i;
          
          }
          }
          
//g<<max<<"\n"
printf("%ld\n",max );
		   
		for(i=pozmax;i!=-1;i=poz[i])
    //g<<a[i]<<" ";
	printf("%ld ",a[i]);
   
    return 0;

}