#include <iostream>
#include <fstream>
using namespace std;
ifstream f("scmax.in");
ofstream g("scmax.out");
int lung[100],a[100],j,n,mx,poz;
void citire(int a[100], int n, int i)
{
if(i<n)
{
f>>a[i];
return citire(a,n,i+1);
}
}
void vlung(int lung[100], int n, int i)
{
if (i>=0)
{
int mx=0;
for(j=i+1;j<n;j++)
if(a[i]<a[j])
if(mx<lung[j])
mx=lung[j];
lung[i]=mx+1;
vlung (lung, n,i-1);
}
}
void solve(int lung[100], int n, int i, int &mx)
{
if(i<n)
if(mx<lung[i])
{
mx=lung[i];
poz=i;
}
else
solve(lung, n,i+1,mx);
}
void done(int lung[100], int a[100], int i, int n, int &poz, int &mx)
{
if (i<n)
if(lung[i]==mx-1 && a[i]>=a[poz])
{
g << a[i]<< " ";
poz=i;
mx--;
}
else
done(lung, a,i+1,n,poz,mx);
}
int main()
{
f >> n;
citire(a,n,0);
lung[n-1]=1;
vlung(lung,n,n);
mx=lung[0];
poz=0;
solve(lung,n,1,mx);
g<<mx<<endl;
g << a[poz]<<" ";
done(lung,a,poz+1,n,poz,mx);
}