Pagini recente » Cod sursa (job #491341) | Cod sursa (job #1142928) | Cod sursa (job #320435) | Cod sursa (job #1661143) | Cod sursa (job #798418)
Cod sursa(job #798418)
#include<fstream>
using namespace std;
int a[100005],c[100005],succ[100005],n,poz_max,lung_max;
int main()
{
int i,j;
freopen("scmax.in","r",stdin);
scanf("%d",&n);
for(i=0;i<n;i++) scanf("%d",&a[i]);
freopen("scmax.out","w",stdout);
for(j=n-1;j>=0;j--)
{
//printf("%d ",a[j]);
c[j]=0;
for(i=j+1;i<n;i++)
if(a[j]<a[i] && c[j]<c[i])
{
c[j]=c[i];
succ[j]=i;
}
c[j]++;
if(c[j]>lung_max)
{
poz_max=j;
lung_max=c[j];
}
//printf("%d \n",c[j]);
}
printf("%d \n",lung_max);
i=poz_max;
while(i)
{
printf("%d ",a[i]);
i=succ[i];
}
printf("\n");
return 0;
}