Pagini recente » Cod sursa (job #417350) | Cod sursa (job #959290) | Cod sursa (job #978305) | Cod sursa (job #1820352) | Cod sursa (job #485366)
Cod sursa(job #485366)
#include <cstdio>
using namespace std;
int a[100020],n,Lpoz[100020],Li[100020];
int main()
{
freopen("scmax.in","r",stdin);
freopen("scmax.out","w",stdout);
scanf("%d",&n);
for (int i=0;i<n;i++)
scanf("%d",&a[i]);
for (int i=0;i<n;i++)
{
Lpoz[i]=-1;
Li[i]=1;
}
int lmax=0,llpoz;
for (int i=n-2;i>=0;i--)
{
int j=i+1;
while(j<n)
{
if(a[i]<a[j])
{
Li[i]+=Li[j];
if(Li[i]>lmax)
{lmax=Li[i];
llpoz=j-1;
}
Lpoz[i]=j;
break;
}
j++;
}
}
printf("%d\n",lmax);
for (int i=0;i<lmax;i++)
{
printf("%d ",a[llpoz]);
llpoz=Lpoz[llpoz];
}
return 0;
}