Pagini recente » Cod sursa (job #1338086) | Cod sursa (job #1932042) | Cod sursa (job #2249353) | Cod sursa (job #1999689) | Cod sursa (job #415533)
Cod sursa(job #415533)
// http://infoarena.ro/problema/subsir2
#include <cstdio>
int n,a[5001],b[5001];
void citire()
{
freopen ("subsir2.in","r",stdin);
scanf("%d", &n);
for (int i=1;i<=n;i++)
scanf("%d", &a[i]);
}
int main()
{
int i,j,max,maxi;
citire();
b[n]=1;
max=0;
for (i=n-1; i>=1; i--)
{
for (j=i+1; j<=n; j++)
if(a[i]<a[j] && b[i]<b[j]) b[i]=b[j];
b[i]++;
if(b[i]>max) max=b[i],maxi=i;
}
freopen ("subsir2.out","w",stdout);
printf ("%d\n%d ", max, a[maxi]);
i=maxi;
for (j=1;j<=n;j++)
if (b[j]==b[i]-1 && a[j]>a[i])
{
printf("%d ", a[j]);
i=j;
}
return 0;
}