Cod sursa(job #3227593)

Utilizator CXHRISXhamani Christian CXHRIS Data 2 mai 2024 09:12:28
Problema Subsir crescator maximal Scor 40
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.95 kb
//nlogn
#include <bits/stdc++.h>
#define maxN 10005
using namespace std;
int n, i, j, v[maxN], sol[maxN], lu[maxN], pozitii[maxN];
int st, dr, mij, poz, k;
int main()
{
    ifstream f("scmax.in");
    ofstream g("scmax.out");
    f >> n;
    for(i = 1; i <= n; i ++)
        f >> v[i];
    for(i = 1; i <= n; i ++)
    {
        if(v[i] > sol[k]) sol[++ k] = v[i], pozitii[k] = i, lu[i] = k;
        else
        {
            st = 1, dr = k, poz = k;
            while(st <= dr)
            {
                mij = (st + dr) / 2;
                if(sol[mij] < v[i]) st = mij + 1;
                    else dr = mij - 1, poz = mij;
            }
            sol[poz] = v[i], pozitii[poz] = i;
            lu[i] = poz;
        }
    }
    g << k << '\n';
    for(i = n, j = 0; i > 0 && k; i --)
        if(lu[i] == k) sol[++ j] = v[i], pozitii[j] = i, k --;
    for(i = j; i >= 1; i --)
        g << pozitii[i] << " ";
    return 0;
}