174. 地下城游戏 -- 动规

174. 地下城游戏

python 复制代码
class CalculateMinimumHP:
    """
    174. 地下城游戏
    https://leetcode.cn/problems/dungeon-game/
    """
    def solution(self, dungeon: List[List[int]]) -> int:
        # 我们想计算左上⻆到右下⻆所需的最⼩⽣命值
        m, n = len(dungeon), len(dungeon[0])
        self.memo = [[-1 for _ in range(n)] for _ in range(m)]
        return self.dp(dungeon, 0, 0)

    def dp(self, grid, i, j):
        """
        从 grid[i][j] 到达终点(右下⻆)所需的最少⽣命值
        :param grid:
        :param i:
        :param j:
        :return:
        """
        m, n = len(grid), len(grid[0])
        # base case
        if i == m - 1 and j == n - 1:
            return 1 if grid[i][j] >= 0 else -grid[i][j] + 1

        if i == m or j == n:
            return float('inf')

        if self.memo[i][j] != -1:
            return self.memo[i][j]

        res = min(self.dp(grid, i, j+1),
                  self.dp(grid, i+1, j)) - grid[i][j]

        self.memo[i][j] = 1 if res <= 0 else res
        return self.memo[i][j]
相关推荐
逝雪Yuki18 小时前
P4017 最大食物链计数
c++·算法·动态规划·拓扑排序·洛谷
舟舟亢亢20 小时前
算法总结—【动态规划一维、二维、状态压缩】
算法·动态规划
重生之后端学习20 小时前
152. 乘积最大子数组
数据结构·算法·leetcode·职场和发展·动态规划
Trouvaille ~21 小时前
【递归、搜索与回溯】专题(八):记忆化搜索——从暴力递归到动态规划的桥梁
c++·算法·leetcode·青少年编程·面试·蓝桥杯·动态规划
仟濹1 天前
【算法打卡day19(2026-03-11 周三)算法:打家劫舍-DP,双指针,二分查找,滑动窗口,方向控制,前缀和 】8个题
算法·leetcode·二分查找·动态规划
@H³M1 天前
面试_动态规划
面试·职场和发展·动态规划
I_LPL1 天前
hot 100 普通数组、矩阵专题
java·数据结构·矩阵·动态规划·贪心·数组·求职面试
仰泳的熊猫1 天前
题目2086:蓝桥杯算法提高VIP-最长公共子序列
数据结构·c++·算法·蓝桥杯·动态规划
Darkwanderor1 天前
图论——拓扑排序和图上DP
c++·算法·动态规划·图论·拓扑排序
zephyr0515 天前
DP 从放弃到拿捏:一份持续更新的动态规划题解清单(一)
算法·动态规划