#include<bits/stdc++.h>
using namespace std;
int n,a[10001],dp[10001],ans;
int main()
{
cin>>n;
for(int i=1;i<=n;i++) cin>>a[i];
dp[1]=1;
for(int i=2;i<=n;i++){
for(int j=i-1;j>=1;j--){
if(a[i]>a[j]){
dp[i]=max(dp[i],dp[j]+1);
}
}
}
for(int i=1;i<=n;i++){
ans=max(ans,dp[i]);
}
cout<<ans;
return 0;
}
//3,18,7,14,10,12,23,41,16,24
//1 2 2 3 3 4
/**************************************************************
Problem: 1794
User: lujiaye
Language: C++
Result: Wrong Answer
****************************************************************/