Pagini recente » Cod sursa (job #2131069) | Cod sursa (job #1880886) | Cod sursa (job #2492551) | Cod sursa (job #684190) | Cod sursa (job #329742)
Cod sursa(job #329742)
#include <iostream.h>
#include <stdio.h>
long int v[100001],n,primu,i,j,a[100001];
struct
{long int adr,val;} best[100001],maxbest;
int main()
{freopen("scmax.in","r",stdin);freopen("scmax.out","w",stdout);
scanf("%ld",&n);
for(i=1;i<=n;i++) scanf("%ld",&v[i]);
for(i=1;i<=n;i++)
{best[i].val=1;maxbest.val=0;maxbest.adr=0;
for(j=1;j<i;j++)
if(best[j].val>maxbest.val && v[j]<v[i])
{maxbest.val=best[j].val;maxbest.adr=j;}
best[i].val+=maxbest.val;best[i].adr=maxbest.adr;
}
for(i=2,maxbest=best[1];i<=n;i++)
if(maxbest.val<best[i].val)
{maxbest=best[i];primu=i;}
printf("%ld\n",maxbest.val);
a[i=1]=v[primu];
while(maxbest.adr!=0)
{a[++i]=v[maxbest.adr];
maxbest=best[maxbest.adr];
}
for(;i>=1;i--) printf("%ld ",a[i]);
printf("\n");fclose(stdin);fclose(stdout);
return 0;}