Cod sursa(job #329742)

Utilizator xtremespeedzeal xtreme Data 7 iulie 2009 12:52:46
Problema Subsir crescator maximal Scor 70
Compilator cpp Status done
Runda Arhiva educationala Marime 1.02 kb
#include <iostream.h>
#include <stdio.h>

long int v[100001],n,primu,i,j,a[100001];
struct 
       {long int adr,val;} best[100001],maxbest;


int main()
    {freopen("scmax.in","r",stdin);freopen("scmax.out","w",stdout);
    scanf("%ld",&n);
    for(i=1;i<=n;i++)        scanf("%ld",&v[i]);
    for(i=1;i<=n;i++)
            {best[i].val=1;maxbest.val=0;maxbest.adr=0;
            for(j=1;j<i;j++)
                      if(best[j].val>maxbest.val && v[j]<v[i])
                                    {maxbest.val=best[j].val;maxbest.adr=j;}
            best[i].val+=maxbest.val;best[i].adr=maxbest.adr;
            }
   for(i=2,maxbest=best[1];i<=n;i++)
         if(maxbest.val<best[i].val)
                     {maxbest=best[i];primu=i;}
   printf("%ld\n",maxbest.val);
   a[i=1]=v[primu];
   while(maxbest.adr!=0)
               {a[++i]=v[maxbest.adr];
               maxbest=best[maxbest.adr];
               }
   for(;i>=1;i--)   printf("%ld ",a[i]);
   printf("\n");fclose(stdin);fclose(stdout);
   return 0;}