Cod sursa(job #3321571)

Utilizator LucaMirsolea14Luca Mirsolea LucaMirsolea14 Data 10 noiembrie 2025 11:07:54
Problema Subsir crescator maximal Scor 65
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.74 kb
#include<bits/stdc++.h>
using namespace std;
ifstream fin("scmax.in");
ofstream fout("scmax.out");

int n, v[100002], tata[100002], u[100002],k;

int cb(int x){

    int st, dr, mij, ans=0;

    st=1;
    dr=k;

    while(st <= dr){
        mij = (st+dr) / 2;
        if(v[u[mij]] < x){
            ans = mij;
            st = mij+1;
        }
        else
            dr = mij-1;
    }
    if(ans == k)
        k++;
    return ans;
}

int main(){

    int i,j,poz;

    fin >> n;

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

    for(i=1;i<=n;i++){
        poz = cb(v[i]);
        u[poz+1] = i;
        tata[i] = u[poz];
    }

    fout << k << '\n';
    for(i=1;i<=k;i++)
        fout << v[u[i]] << " ";
}