Cod sursa(job #2130194)

Utilizator andreiomd1Onut Andrei andreiomd1 Data 13 februarie 2018 15:28:27
Problema Subsir crescator maximal Scor 70
Compilator cpp Status done
Runda Arhiva educationala Marime 0.83 kb
#include <fstream>

using namespace std;

ifstream f("scmax.in");
ofstream g("scmax.out");

long long int a[100005];
int n,l[100005];
int i,j,Max=0;
int lmax=0,poz;
int b[100005];
int nr=0;

int main()
{
    f>>n;
    for(i=1; i<=n; i++)
        f>>a[i];
    l[1]=1;
    lmax=1;
    poz=1;
    for(i=2; i<=n; i++)
    {
        Max=0;
        for(j=1; j<i; j++)
            if(l[j]>Max&&a[j]<a[i])
                Max=l[j];
        l[i]=Max+1;
        if(l[i]>lmax)
        {
            lmax=l[i];
            poz=i;
        }

    }
    g<<lmax<<'\n';
    b[1]=a[poz];
    lmax--;
    nr=1;
    for(i=poz-1; i>=1; i--)
        if(a[i]<b[nr]&&l[i]==lmax)
        {
            b[++nr]=a[i];
            lmax--;
        }
    for(i=nr; i>=1; i--)
        g<<b[i]<<' ';
    g<<'\n';
    return 0;
}