#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
const int N = 1010;
int a[N];
int f[N];
int main(){
int n;
cin>>n;
for(int i=0;i<n;i++) cin>>a[i];
int res=0;
for(int i=0;i<n;i++){
f[i]=1;
for(int j=0;j<i;j++){
if(a[j]<a[i]) f[i]=max(f[j]+1,f[i]);
}
res=max(res,f[i]);
}
cout<<res;
return 0;
}