Pagini recente » Cod sursa (job #1936526) | Cod sursa (job #2712037) | Cod sursa (job #741195) | Cod sursa (job #337877) | Cod sursa (job #780620)
Cod sursa(job #780620)
#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){
if(k > 0)
for(int i=n;i>0;i--)
if( bst[i] == k )
{
k--;
tipar(n-1);
printf("%d\n",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);
//for(int i=1;i<=n;i++)printf("%d ",bst[i]);
return 0;
}