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]
相关推荐
我家大宝最可爱13 小时前
动态规划:入门思考篇
算法·动态规划·代理模式
自信的小螺丝钉18 小时前
Leetcode 343. 整数拆分 动态规划
算法·leetcode·动态规划
Tisfy1 天前
LeetCode 837.新 21 点:动态规划+滑动窗口
数学·算法·leetcode·动态规划·dp·滑动窗口·概率
利刃大大1 天前
【动态规划:路径问题】最小路径和 && 地下城游戏
算法·动态规划·cpp·路径问题
tkevinjd1 天前
图论\dp 两题
leetcode·动态规划·图论
烧冻鸡翅QAQ3 天前
62.不同路径
算法·动态规划
一只鱼^_3 天前
牛客周赛 Round 105
数据结构·c++·算法·均值算法·逻辑回归·动态规划·启发式算法
是阿建吖!3 天前
【动态规划】斐波那契数列模型
算法·动态规划
小七rrrrr4 天前
动态规划法 - 53. 最大子数组和
java·算法·动态规划
何妨重温wdys4 天前
矩阵链相乘的最少乘法次数(动态规划解法)
c++·算法·矩阵·动态规划