Cod sursa(job #1724587)

Utilizator pionierul22aNa LiZa pionierul22 Data 3 iulie 2016 15:59:15
Problema Subsir crescator maximal Scor 70
Compilator cpp Status done
Runda Arhiva educationala Marime 0.66 kb
#include <fstream>
using namespace std;
ifstream fin("scmax.in");
ofstream fout("scmax.out");
int a[100000],best[100000],poz[100000],i,j,maxi,p,n;
int main()
{
    fin>>n;
    for(i=1;i<=n;i++)
        fin>>a[i];


  best[n]=1;
  poz[n]=-1;
  maxi=1; p=n;
  for(i=n-1;i>=1;--i)
   {
   best[i]=1;
   poz[i]=-1;
   for(j=i+1;j<=n;++j)
       if(a[i]<a[j] && best[i]<best[j]+1)
         {
         best[i]=best[j]+1;
         poz[i]=j;
         if(best[i]>maxi) {maxi=best[i];
            p=i;}
         }
   }



    fout<<maxi<<'\n';
    i=p;
    while(i!=-1)
    {
        fout<<a[i]<<" ";
        i=poz[i];
    }


    return 0;
}