Pagini recente » Cod sursa (job #3285389) | Cod sursa (job #2918185) | Cod sursa (job #3264298) | Istoria paginii preoni-2007/clasament/runda-1/10 | Cod sursa (job #1333099)
#include <cstdio>
using namespace std;
int a[100010],l[100010],max,m,i,n,j,poz,p,t[100010];
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]);
l[n]=1; t[n]=-1;
for (i=n-1; i>=1; i--)
{
max=0;
p=-1;
for (j=i+1; j<=n; j++)
if (a[j]>a[i] && l[j]+1>l[i])
if (l[j]>max) { max=l[j]; p=j; }
l[i]=max+1; t[i]=p;
if (l[i]>m) {m=l[i]; poz=i;}
}
printf("%d\n",m);
while (poz!=-1)
{
printf("%d ",a[poz]);
poz=t[poz];
}
return 0;
}