Cod sursa(job #1635324)

Utilizator andrei.sasaAndrei SaSa andrei.sasa Data 6 martie 2016 16:40:29
Problema Subsir crescator maximal Scor 20
Compilator cpp Status done
Runda Arhiva educationala Marime 0.65 kb
#include <iostream>
#include <fstream>

using namespace std;

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

int x[100001],z[100001],n,i,smax,j,start[100001],ok;

int main()
{
    f >> n;
    for (i=1;i<=n;i++)
        f >> x[i];
    z[n]=1;start[n]=0;
    for (i=n-1;i>=1;i--)
    {
        ok=0;
        for (j=1;j<=n;j++)
            if (x[i]<x[j] && z[i]<z[j]) {z[i]=z[j]+1;start[i]=j;ok=1;}
        if (!ok) {z[i]=1; start[i]=0;}
        if (z[i]>z[smax]) smax=i;
    }
    g << z[smax] << "\n";
    while (start[smax])
    {
        g << x[smax] << ' ';
        smax=start[smax];
    }
    g << x[smax];

    return 0;
}