最长不下降子序列:
样例输入:
5
1 3 1 2 2
样例输出:
4
#include<bits/stdc++.h>
using namespace std;
int n;
int a[5005];
int f[5005];
int main(){
while(cin>>n){
for(int i=1;i<=n;i++){
cin>>a[i];
f[i]=1;//初始化最长非下降子序列长度最小值为1
}
int ans=0;
for(int i=1;i<=n;i++){
for(int j=1;j<i;j++){
if(a[i]>=a[j]&&f[j]+1>f[i]){//i之前(即j)有多个数比i小时需要取其中最大的f[i]
f[i]=f[j]+1;
}
}
//取最大值
if(f[i]>ans){
ans=f[i];
}
}
/*sort(f,f+n+1);
cout<<f[n]<<endl;*/
cout<<ans<<endl;
}
return 0;
}