「已注销」 2023-04-19 23:26 采纳率: 90.2%
浏览 10
已结题

C++动态规划DP题

DP题,马前卒,代码求指正
思路是用map记录障碍点(记为1),dp时若非1则dp[i][j]=dp[i-1][j]+dp[i][j-1]
原题洛谷:https://www.luogu.com.cn/problem/P1002


#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#define INF 1e9
using namespace std;

int dx[]={-2,-1,1,2,-2,-1,1,2};
int dy[]={-1,-2,-2,-1,1,2,2,1};
bool map[22][22];
int dp[22][22];

int Bx,By,Hx,Hy;
//dp[i][j]=dp[i-1][j]+dp[i][j-1]
int main(){
    memset(map,0,sizeof(map));
    cin>>Bx>>By>>Hx>>Hy;
    map[Hx][Hy]=1;
    for(int i=0;i<8;i++){
        int x=Hx+dx[i];
        int y=Hx+dy[i];
        if(x<0||y<0||x>Bx||y>By)continue;
        map[x][y]=1;
    }
    dp[0][1]=1;
    for(int i=1;i<Bx;i++){
        for(int j=1;j<By;j++){
            if(map[i][j]==0)dp[i][j]=dp[i-1][j]+dp[i][j-1];
        }
    }
    cout<<dp[Bx-1][By-1];
    return 0;
} 
  • 写回答

2条回答 默认 最新

  • 关注

    看了代码有以下几个问题:

    1.在记录是否为障碍物的数组中,应该将其定义为bool类型而不是int类型,因为它只有两个取值,0和1。

    2.在记录是否为障碍物的数组中,应该将x和y的计算分别赋值给x和y,而不是将y赋值给x,这是因为y是dy数组中的元素,而dx数组中的元素应该赋值给x。

    3.在dp的过程中,应该从0开始循环到Bx和By,而不是从1开始循环到Bx-1和By-1,因为dp[0][0]表示的是起点,而dp[Bx-1][By-1]表示的是终点。

    4.dp[i][j]应该只在map[i][j]等于0的情况下更新,因为map[i][j]等于1表示这个点是障碍物,无法通过。

    这个是修改过后的代码,你可以参考一下

    #include <cstdio>
    #include <iostream>
    #include <algorithm>
    #include <cstring>
    #define INF 1e9
    using namespace std;
    
    int dx[] = {-2, -1, 1, 2, -2, -1, 1, 2};
    int dy[] = {-1, -2, -2, -1, 1, 2, 2, 1};
    bool map[22][22];
    int dp[22][22];
    
    int Bx, By, Hx, Hy;
    
    int main() {
        memset(map, 0, sizeof(map));
        cin >> Bx >> By >> Hx >> Hy;
        map[Hx][Hy] = true;
        for(int i = 0; i < 8; i++) {
            int x = Hx + dx[i];
            int y = Hy + dy[i];
            if(x < 0 || y < 0 || x > Bx || y > By) continue;
            map[x][y] = true;
        }
        dp[0][0] = 1;
        for(int i = 0; i <= Bx; i++) {
            for(int j = 0; j <= By; j++) {
                if(!map[i][j]) {
                    if(i == 0 && j == 0) continue;
                    if(i == 0) dp[i][j] = dp[i][j-1];
                    else if(j == 0) dp[i][j] = dp[i-1][j];
                    else dp[i][j] = dp[i-1][j] + dp[i][j-1];
                }
            }
        }
        cout << dp[Bx][By] << endl;
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月28日
  • 已采纳回答 4月20日
  • 创建了问题 4月19日

悬赏问题

  • ¥20 java在应用程序里获取不到扬声器设备
  • ¥15 echarts动画效果的问题,请帮我添加一个动画。不要机器人回答。
  • ¥60 许可证msc licensing软件报错显示已有相同版本软件,但是下一步显示无法读取日志目录。
  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
  • ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事:
  • ¥15 前置放大电路与功率放大电路相连放大倍数出现问题
  • ¥30 关于<main>标签页面跳转的问题
  • ¥80 部署运行web自动化项目
  • ¥15 腾讯云如何建立同一个项目中物模型之间的联系