Pagini recente » Cod sursa (job #847738) | Cod sursa (job #623864) | Cod sursa (job #2284447) | Cod sursa (job #2172468) | Cod sursa (job #1635324)
#include <iostream>
#include <fstream>
using namespace std;
ifstream f ("scmax.in");
ofstream g ("scmax.out");
int x[100001],z[100001],n,i,smax,j,start[100001],ok;
int main()
{
f >> n;
for (i=1;i<=n;i++)
f >> x[i];
z[n]=1;start[n]=0;
for (i=n-1;i>=1;i--)
{
ok=0;
for (j=1;j<=n;j++)
if (x[i]<x[j] && z[i]<z[j]) {z[i]=z[j]+1;start[i]=j;ok=1;}
if (!ok) {z[i]=1; start[i]=0;}
if (z[i]>z[smax]) smax=i;
}
g << z[smax] << "\n";
while (start[smax])
{
g << x[smax] << ' ';
smax=start[smax];
}
g << x[smax];
return 0;
}