#include<bits/stdc++.h>
using namespace std;
int a[1010],n,ans;
int dp[1010];//表示剩余j个时
//最多能有 个满足条件
void init()
{
cin>>n;
for(int i=1;i<=n;i++)
cin>>a[i];
}
void DP()
{
for(int i=1;i<=n;i++)
{
for(int j=i;j>=1;j--)
dp[j]=max(dp[j],dp[j-1]+(a[i]==j?1:0));
}//然后,找到最大的
for(int i=0;i<=n;i++)
ans=max(ans,dp[i]);
}
int main()
{
init();
DP();
cout<<ans<<endl;
return 0;
}