fengquanqing @ 2023-07-27 09:33:19
#include<bits/stdc++.h>
using namespace std;
int n,mx=INT_MIN;
int a[100010],b[100010],f[100050];
int main(){
cin>>n;
for(int i=1;i<=n;i++){
cin>>a[i];
f[i]=1;
}
for(int i=2;i<n;i++){
for(int j=1;j<i;j++){
if(a[j]<a[i]){
f[i]=max(f[i],f[j]+1);
}
}
mx=max(mx,f[i]);
}
cout<<mx;
return 0;
}
我用的dp做的,测试点2没过,求助!
by wzzzh @ 2023-07-27 09:53:02
@fengquanqing 你把第 n
个数落了(
@@ -10,12 +10,12 @@
}
- for(int i=2;i<n;i++){
+ for(int i=2;i<=n;i++){
for(int j=1;j<i;j++){
by SealMoBurp @ 2023-07-27 09:55:57
@fengquanqing
for(int i=2;i<n;i++){
这句改成
for(int i=1;i<=n;i++){
试试
by fengquanqing @ 2023-07-27 09:58:10
已AC,谢谢!