代码如下,写了个DP
#include<bits/stdc++.h>
using namespace std;
const int N=10010;
int a[N],n;
int f[N];int ans=0;
int main()
{
cin>>n;
for(int i=1;i<=n;i++)
{
cin>>a[i];
f[i]=1;
}
int res=0;
for(int i=1;i<=n;i++)
{
for(int j=0;j<i;j++)
if(a[i]==a[j]+1) f[i]=max(f[i],f[j]+1);
res=max(res,f[i]);
}
cout<<res;
return 0;
}