Cod sursa(job #2635668)

Utilizator Leonard123Mirt Leonard Leonard123 Data 15 iulie 2020 12:14:10
Problema Subsir crescator maximal Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.73 kb
#include<bits/stdc++.h>
#define maxn 100050
using namespace std;

int a[maxn],q[maxn],p[maxn],n,len;

int solve(int x,int st,int dr){
    int md=(st+dr)/2;
    if(st==dr){
        if(dr>len) ++len;
        q[st]=x;
        return st;
    }else if(x<=q[md]) solve(x,st,md);
        else solve(x, md+1, dr);
}

void print(int x, int y){
    if(x){
        if(p[y]==x)
            print(x-1,y-1), cout<<a[y]<<' ';
        else print(x,y-1);        
    }else cout<<len<<'\n';
}

int main(){
    freopen("scmax.in","r",stdin);
    freopen("scmax.out","w",stdout);
    ios_base::sync_with_stdio(0);
    cin.tie(0);
    cin>>n;
    for(int i=1; i<=n; i++)
        cin>>a[i];
    for(int i=1; i<=n; i++)
        p[i]=solve(a[i],1,len+1);
    print(len,n);
}