Pagini recente » Cod sursa (job #2826258) | Cod sursa (job #1006239) | Cod sursa (job #2285877) | Cod sursa (job #39894) | Cod sursa (job #251889)
Cod sursa(job #251889)
#include <cstdio>
#define N 100001
int A[N],urm[N],C[N],n,i,j,max,pmax,maxt;
int main()
{
freopen("scmax.in","r",stdin);
freopen("scmax.out","w",stdout);
scanf("%d\n",&n);
for (i=1; i<=n; i++) scanf("%d",&A[i]);
C[n]=1; maxt=0;
for (i=n-1; i; i--)
{
max=0;
for (j=i+1; j<=n; j++)
if (A[j]>A[i] && C[j]>max)
{
max=C[j];
urm[i]=j;
}
C[i]=++max;
if (max>maxt)
{
maxt=max;
pmax=i;
}
}
printf("%d\n",maxt);
for (i=pmax; i; i=urm[i]) printf("%d ",A[i]);
return 0;
}