WA80,dp求助!

B3637 最长上升子序列

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,谢谢!


|