#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=5555;//一般只能几千数量级
ll a[N];
ll dp[N];
//dp[i],表示前i个数字,
//以a[i]结尾的最长上升子序列长度
void solve()
{
ll n,ans=0;cin>>n;
for(int i=1;i<=n;i++)
{
cin>>a[i];
dp[i]=1;
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=i;j++)
{
if(a[j]<a[i])
{
dp[i]=max(dp[i],dp[j]+1);
}
}
ans=max(ans,dp[i]);
}
cout<<ans;
}
int main()
{
solve();
}
最长上升子序列(LIS)
最新推荐文章于 2024-09-12 19:02:20 发布