社区讨论

求助dp,玄关

学术版参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@m06mi1ts
此快照首次捕获于
2024/08/23 19:23
2 年前
此快照最后确认于
2024/08/23 21:35
2 年前
查看原帖
P1353
CPP
#include<bits/stdc++.h>
using namespace std;
int d[10005],dp[10005][505][2],n,m;
int main(){
    cin>>n>>m;
    for(int i=1;i<=n;i++)cin>>d[i];
    for(int j=1;j<=m;j++){
        for(int k=0;k<=1;k++){
            if(!k)dp[1][j][k]=0;
            else dp[1][j][k]=d[1];
        }
    }
    for(int i=2;i<=n;i++){
        dp[i][0][0]=max(dp[i-1][1][0],dp[i-1][1][1]);
        for(int j=1;j<=m;j++){
            if(j+1>m){dp[i][j][0]=max(dp[i-1][j-1][0],dp[i-1][j-1][1]),dp[i][j][1]=0;continue;}
            dp[i][j][0]=max(dp[i-1][j-1][0],dp[i-1][j-1][1]);
            dp[i][j][1]=max(dp[i-1][j+1][0]+d[i],dp[i-1][j+1][1]+d[i]);
        }
    }
    cout<<max(dp[n][0][0],dp[n][0][1]);
}

回复

0 条回复,欢迎继续交流。

正在加载回复...