Cod sursa(job #1047725)

Utilizator adrian6Adrian Berteanu adrian6 Data 4 decembrie 2013 20:37:28
Problema Subsir crescator maximal Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.7 kb
#include<fstream>
#include<iostream>
using namespace std;
ifstream f("scmax.in");
ofstream g("scmax.out");
int n,i,Lm,p,L[101],a[101],nr;
void dinamica()
{
    int i,j,max;
    L[n]=1;
    for(i=n-1;i>=1;i--)
    {
        max=0;
        for(j=1;j<=n;j++)
        if(L[j]>max && a[i]<a[j])
        max=L[j];
        L[i]=max+1;
        if(Lm<L[i])
        Lm=L[i];
    }
}
void drum()
{
    int t;
    t=0;
    p=1;
    do
    {
        while(L[p]!=Lm || a[t]>a[p])
        {p++;nr++;}
        g<<a[p]<<" ";
        t=p;
        Lm--;
    }
    while(Lm);
}
int main()
{
    f>>n;
    for(i=1;i<=n;i++)
    f>>a[i];
    g<<nr<<endl;
    dinamica();
    drum();
return 0;
}