Pagini recente » Cod sursa (job #2050979) | Cod sursa (job #417512) | Cod sursa (job #756648) | Cod sursa (job #2613092) | Cod sursa (job #1054225)
#include <iostream>
#include<fstream>
using namespace std;
int v[100001],i,n,j,k,b[100001],p[1000001];
ifstream f("scmax.in");
ofstream g("scmax.out");
void rez()
{
unsigned int max,ok,x=0,k=0;
b[1]=1;
for(i=2;i<=n;i++)
{
max=0;
for(j=1;j<i;j++)
if(v[j]<v[i]&&b[j]>max)
max=b[j];
b[i]=max+1;
if(x<b[i])
{
x=b[i];
}
}
max=0;
g<<x<<endl;
for(i=1;i<=n;i++)
{
if(max<b[i])
{
max=b[i];
while(b[i+1]==max)
{
ok=1;
i++;
}
if(ok&&k<x)
{
g<<v[i]<<" ";
k++;
}
}
}
}
int main()
{
f>>n;
for(i=1;i<=n;i++)
f>>v[i];
rez();
return 0;
}