Pagini recente » Cod sursa (job #424731) | Cod sursa (job #302690) | Cod sursa (job #1064845) | Cod sursa (job #474736) | Cod sursa (job #681625)
Cod sursa(job #681625)
#include<cstdio>
using namespace std;
int n, a[100001],l[100001],poz[100001];
int main()
{
freopen("scmax.in","r",stdin);
freopen("scmax.out","w",stdout);
int i,j,max,pmax;
scanf("%d",&n);
for(i=1;i<=n;i++)
scanf("%d",&a[i]);
l[n]=1;
poz[n]=-1;
for(i=n-1;i>0;i--)
for(l[i]=1, poz[i]=-1, j=i+1; j<=n; j++)
if(a[i]<a[j] && l[i]<1+l[j])
{
l[i]=1+l[j];
poz[i]=j;
}
max=l[1];
pmax=1;
for(i=2;i<=n;i++)
if(max<l[i])
{
max=l[i];
pmax=i;
}
printf("%d\n", max);
for(i=pmax; i!=-1; i=poz[i])
printf("%d ", a[i]);
return 0;
}