#include<bits/stdc++.h>
using namespace std;
int i,j,n,a[20003],m=0,f[20003];
//f[i]是指以i结尾的最长子序列长度
int main()
{
cin>>n;
for(i=1;i<=n;i++)
cin>>a[i],f[i]=1;//子序列只有自身,则长度就是1
for(i=1;i<=n;i++)
{//按照输入的顺序 ,开始计算数值f[i]
for(j=1;j<i;j++)
{
if(a[j]<a[i])
f[i]=max(f[j]+1,f[i]);
//求最大的f[i],从第一个开始比较,一直到i-1(就是f[j])
}
}
while(n--)
{
if(f[n]>m)
m=f[n];
}
cout<<m;
return 0;
}
最长上升子序列
最新推荐文章于 2024-11-06 19:55:44 发布