Cod sursa(job #1800197)

Utilizator sarpe123Iancu Alexandru sarpe123 Data 7 noiembrie 2016 15:24:51
Problema Subsir crescator maximal Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.85 kb
#include <fstream>

using namespace std;
ifstream f("a.in");
ofstream g("a.out");
int n=0,a[100],l[100],ant,val,vmax,i,poz=1;//,ram;
void citire()
{
    int x;
    while(f>>x)
    {
        a[++n]=x;
        l[n]=0;
    }
}
int ss(int x)
{
    int i,maxim=0;
    for (i=x+1;i<=n;i++) if (a[x]<a[i]) if (l[i]>maxim) maxim=l[i];
    return maxim;
}
void afisare (int val)
{
    int i;
    if (val>0)
    {
        for (i=poz;i<=n;i++) if (l[i]==val)
        {
            g<<a[i]<<" ";
            poz=i;
            val--,afisare(val);
            break;
        }
    }
    else return;
}

void scm()
{
    int i,vmax=-1;
    l[n]=1;
    for (i=n-1;i>=1;i--)
    {
        l[i]=ss(i)+1;
        if (l[i]>vmax)vmax=l[i];
    }
    //ram=vmax;
    afisare(vmax);
}
int main()
{
    citire();
    scm();

    return 0;
}