Cod sursa(job #2620618)

Utilizator CosminMorarMorar Cosmin Andrei CosminMorar Data 29 mai 2020 12:23:28
Problema Subsir crescator maximal Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.02 kb
#include <bits/stdc++.h>
using namespace std;
ifstream fin("scmax.in");
ofstream fout("scmax.out");
int n, v[100100], poz[100100], a[100100], len_max, sol[100100];

int bin_search(int x) { /// cautam cea mai din stanga pozitie care are valoarea >= cu x
    int st = 1, dr = len_max;
    while (st <= dr) {
        int mij = (st + dr) / 2;
        if (x > a[mij])
            st = mij + 1;
        else
            dr = mij - 1;
    }
    return st;
}

int main() {
	fin >> n;
	for (int i = 1; i <= n; i++)
		fin >> v[i];

    for (int i = 1; i <= n; i++) {
        int p = bin_search(v[i]);
        if (p > len_max)
            len_max++;
        poz[i] = p; /// retinem lungimea maxima pana la fiecare pozitie
        a[p] = v[i];
    }

    int k = len_max;
    for (int i = n; i >= 1; i--)
        if (poz[i] == k && (k == len_max || sol[k + 1] > v[i]))
            sol[k--] = v[i];

    fout << len_max << '\n';
    for (int i = 1; i <= len_max; i++)
        fout << sol[i] << ' ';
	return 0;
}