Pagini recente » Cod sursa (job #2719053) | Cod sursa (job #2417322) | Cod sursa (job #2927021) | Cod sursa (job #1020800) | Cod sursa (job #713825)
Cod sursa(job #713825)
#include<iostream>
#include<cstdio>
int a[100001],poz[100001],L[100001],max,n,i,j,ok,p;
int main()
{
freopen("scmax.in","r",stdin);
freopen("scmax.out","w",stdout);
scanf("%d",&n);
for(i=1;i<=n;++i)
scanf("%d",&a[i]);
max=1;L[n]=1;p=n;poz[n]=n+1;
for(i=n-1;i>=1;--i)
{
ok=1;
for(j=i+1;j<=n;++j)
if(a[i]<a[j]&&L[i]<=L[j])
{
ok=0;
L[i]=L[j]+1;
poz[i]=j;
if(L[i]>max) max=L[i],p=i;
}
if(ok) L[i]=1,poz[i]=i;
}
printf("%d\n",max);
while(poz[p])
{
printf("%d ",a[p]);
p=poz[p];
}
return 0;
}