题解 100% AC
2025-08-11 21:04:21
发布于:江苏
6阅读
0回复
0点赞
#include<bits/stdc++.h>
using namespace std;
int dp[1005],dd[1005],a[1005],t;
int main(){
    while(cin>>a[t++]);
    t-=1;
    int ans=0,ans2=0;
    for(int i=0;i<t;i++){
        dp[i]=1;
        dd[i]=1;
        for(int j=0;j<i;j++){
            if(a[i]<=a[j])dp[i]=max(dp[i],dp[j]+1);
            if(a[i]>a[j])dd[i]=max(dd[i],dd[j]+1);
        }
        ans=max(ans,dp[i]);
        ans2=max(ans2,dd[i]);
    }
    cout<<ans<<endl<<ans2<<endl;
    return 0;
}
这里空空如也







有帮助,赞一个