「已注销」 2023-03-02 20:30 采纳率: 90.2%
浏览 27
已结题

C++动态规划引入数字三角形

原题洛谷:https://www.luogu.com.cn/problem/P1216
照葫芦画瓢第一次写的DP,但是只通过了2/9,不知道哪里有问题,请求指导

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std;

int dp_function(int n){
    int arr[1001][1001];
    int dp[1001][1001];   //dp[i][j]=max(dp[i-1][j],dp[i-1][j-1])+arr[i][j]//request=dp[n-1][n-1]
    for(int i=0;i<5;i++){
        for(int j=0;j<=i;j++){
        scanf("%d",&arr[i][j]);
        if(i==0)dp[i][j]=arr[i][j];
        if(j==0)dp[i][j]=dp[i-1][j]+arr[i][j];
        }
    }
    for(int i=1;i<n;i++){
        for(int j=1;j<n;j++){
            dp[i][j]=max(dp[i-1][j],dp[i-1][j-1])+arr[i][j];
        }
    }
    return dp[n-1][n-1];
}

int main(){
    int n;
    //dp[i][j]=max(dp[i-1][j],dp[i-1][j-1])+dp[i][j]//request=dp[n-1][n-1]
    scanf("%d",&n);
    printf("%d",dp_function(n));
    return 0;
} 

  • 写回答

2条回答 默认 最新

  • 社区专家-Monster-XH 2023-03-02 22:17
    关注
    • 数组越界
      你的二维数组定义为 int arr[1001][1001],但是只读入了5行数字,所以当n大于5时,数组会越界。正确的定义应该是 int arr[1001][1001] = {0},这样数组中的所有元素都会初始化为0,可以避免数组越界问题。
    • 贪心算法错误
      你的dp转移方程为 dp[i][j]=max(dp[i-1][j],dp[i-1][j-1])+arr[i][j],这是贪心算法的思想,但是这个思想在本题中不适用。因为你要求的是从顶部到底部的最大路径和,但是这个路径上的数并不一定是每一行中的最大值。例如,在样例中,第1行的5是最大值,但是最大路径和的路径是 7->6->9->3->2,其中第1行的5并没有被选中。
    • 变量重复定义
      你在dp_function函数中定义了一个变量 dp,但是这个变量和外面的变量名相同,会导致变量重复定义的错误。建议将内部变量的名称更改为 dpArr。
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月11日
  • 已采纳回答 3月3日
  • 创建了问题 3月2日

悬赏问题

  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效