#include<bits/stdc++.h>
using namespace std;
int n,a[5050],dp[5050];
int main(){
cin>>n;
for(int i=0;i<n;i++) cin>>a[i];
for(int i=0;i<n;i++){
dp[i]=1;
for(int j=i;j>=0;j--){
if(a[j]<a[i]) dp[i]=max(dp[i],dp[j]+1);
}
}
int ans=0;
for(int i=0;i<n;i++){
ans=max(ans,dp[i]);
}
cout<<ans;
return 0;
}