Cod sursa(job #1027868)

Utilizator razvan147258369Lucacel Razvan razvan147258369 Data 13 noiembrie 2013 10:29:59
Problema Subsir crescator maximal Scor 30
Compilator cpp Status done
Runda Arhiva educationala Marime 0.82 kb
#include <iostream>
#include <fstream>
using namespace std;

fstream fin("scmax.in",ios::in);
fstream fout("scmax.out",ios::out);

unsigned long long n,a[1001],l[1001],poz[1001];

int main()
{
    int i,j;
    fin>>n;
    for(i=1;i<=n;i++)
    {
        fin>>a[i];
    }

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

    int max=l[1], pozmax=1;

    for(i=2;i<=n;i++)
    {
        if(max<l[i])
        {
            max=l[i];
            pozmax=i;
        }
    }

    fout<<max<<'\n';
   // fout<<"\nCel mai lung subsir:\n";

    for (i=pozmax; i!=-1; i=poz[i])
        fout<<a[i]<<' ';

}