Pagini recente » Cod sursa (job #2760005) | Cod sursa (job #380597) | Cod sursa (job #2519903) | Cod sursa (job #759463) | Cod sursa (job #780622)
Cod sursa(job #780622)
#include <cstdio>
#include <algorithm>
using namespace std;
#define Max 100001
int n,v[Max],bst[Max],c[Max],k;
int c_bin(int l,int r,int x){
int m;
while(l < r)
{
m = (l+r)/2;
if( c[m] >= x )r = m; else l = m+1;
}
if(r > k)k = r;
c[r] = x;
return r;
}
void tipar(int n,int k){
if(k > 0)
for(int i=n;i>0;i--)
if( bst[i] == k )
{
tipar(i-1,k-1);
printf("%d ",v[i]);
return ;
}
}
int main(){
freopen("scmax.in","r",stdin);
freopen("scmax.out","w",stdout);
scanf("%d",&n);
for(int i=1;i<=n;i++)scanf("%d",&v[i]);
for(int i=1;i<=n;i++)bst[i] = c_bin(1,k+1,v[i]);
printf("%d\n",k);
tipar(n,k);
//for(int i=1;i<=n;i++)printf("%d ",bst[i]);
return 0;
}