leetcode 174 地下城游戏

一、问题描述

二、解题思路

整体思路

本题属于路径相关问题的变形,可以采用动态规划的方法来解决这个问题。

具体思路

(1)dpij含义

由于本题是具有后滞性的动态规划问题,所以不同于一般路径问题dpij表示以(i,j)为终点,本题的dpij表示以(i,j)为起点的最小生命值

(2)状态转移方程

设当前的生命值为x,则有x+dij >= dpi+1j,即x>=dpi+1j-dij,最小生命值为dpi+1j-dij,向下亦然,所以dpij=min(dpi+1j,dpij+1)-dij

注意:由于生命值<=0表示死亡,所以计算后需要执行dpij=max(1,dpij)。

(3)初始化

dp数组为(m+1)*(n+1)的数组,先将所有位置初始化为正无穷,(m-1,n)和(m,n-1)位置初始化为1,为了计算dpm-1n-1的值,以示例一为例,初始化后的数组为:

(4)填表顺序

从后往前,从右向左进行填写。

(5)返回值

dp00即为所求,返回即可。

三、代码实现

cpp 复制代码
class Solution {
public:
    int calculateMinimumHP(vector<vector<int>>& d) {
        //有后效性的动态规划
        int m = d.size();
        int n = d[0].size();
        vector<vector<int>> dp(m+1,vector<int>(n+1,INT_MAX));
        dp[m][n-1] = dp[m-1][n] = 1;

        //从后向前,从右向左,填写dp数组
        for(int row = m-1;row >=0;row--)
            for(int col = n-1;col >=0;col--){
                dp[row][col] = min(dp[row+1][col],dp[row][col+1])-d[row][col];
                dp[row][col] = max(1,dp[row][col]);
            }
        //返回值
        return dp[0][0];
    }
};
相关推荐
折哥的程序人生 · 物流技术专研4 小时前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)
java·网络·数据库·算法·面试
玖玥拾5 小时前
C/C++ 基础笔记(十四)多态与模板编程
c语言·c++·多态·模板
想吃火锅10055 小时前
【leetcode】14.最长公共前缀js
算法·leetcode·职场和发展
Roann_seo%5 小时前
C++文件操作完全指南:从文本读写到二进制文件处理
开发语言·c++
坚果派·白晓明6 小时前
【鸿蒙PC】SDL3 适配:AtomCode + Skills 快速集成 NAPI 测试工具
c++·华为·ai编程·harmonyos·atomcode
云絮.7 小时前
数据库操作
数据库·mysql·算法·oracle
小林ixn7 小时前
LeetCode 206. 反转链表(迭代 + 递归详解)
算法·leetcode·链表
凡人叶枫7 小时前
Effective C++ 条款17:以独立语句将 newed 对象置入智能指针
java·linux·开发语言·c++·算法
我爱cope8 小时前
【Agent智能体26 | 多智能体-多智能体工作流】
人工智能·设计模式·语言模型·职场和发展
凡人叶枫8 小时前
Effective C++ 条款16:成对使用 new 和 delete 时要采取相同形式
开发语言·c++·effective c++