Cod sursa(job #1526767)

Utilizator leonard.david42Bereholschi Leonard David leonard.david42 Data 17 noiembrie 2015 10:48:30
Problema Subsir crescator maximal Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 1.22 kb
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("scmax.in");
ofstream g("scmax.out");
int lung[100],a[100],j,n,mx,poz;
void citire(int a[100], int n, int i)
{
    if(i<n)
    {
        f>>a[i];
        return citire(a,n,i+1);
    }
}
void vlung(int lung[100], int n, int i)
{
    if (i>=0)
    {
        int mx=0;
        for(j=i+1;j<n;j++)
            if(a[i]<a[j])
                if(mx<lung[j])
                    mx=lung[j];
        lung[i]=mx+1;
        vlung (lung, n,i-1);
    }
}
void solve(int lung[100], int n, int i, int &mx)
{
    if(i<n)
        if(mx<lung[i])
        {
            mx=lung[i];
            poz=i;
        }
        else
            solve(lung, n,i+1,mx);
}
void done(int lung[100], int a[100], int i, int n, int &poz, int &mx)
{
    if (i<n)
        if(lung[i]==mx-1 && a[i]>=a[poz])
        {
            g << a[i]<< " ";
            poz=i;
            mx--;
        }
        else
            done(lung, a,i+1,n,poz,mx);
}
int main()
{
    f >> n;
    citire(a,n,0);
    lung[n-1]=1;
    vlung(lung,n,n);
    mx=lung[0];
    poz=0;
    solve(lung,n,1,mx);
    g<<mx<<endl;
    g << a[poz]<<" ";
    done(lung,a,poz+1,n,poz,mx);
}