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]
相关推荐
如何原谅奋力过但无声10 小时前
【chap11-动态规划(上 - 基础题目&背包问题)】用Python3刷《代码随想录》
数据结构·python·算法·动态规划
客卿12312 小时前
动态规划--模板--完全背包
算法·动态规划
VelinX13 小时前
【个人学习||算法】多维动态规划
学习·算法·动态规划
ZoeJoy819 小时前
算法筑基(六):分治算法——大事化小,小事化了
算法·排序算法·动态规划·哈希算法·图搜索算法
故事和你912 天前
洛谷-入门4-数组3
开发语言·数据结构·c++·算法·动态规划·图论
czlczl200209252 天前
力扣1911. 最大交替子序列和
算法·leetcode·动态规划
小范自学编程3 天前
算法训练营Day44 - 动态规划part12
算法·动态规划
努力学习的小廉3 天前
我爱学算法之——动态规划(一)
算法·动态规划
EQUINOX13 天前
马尔可夫链
线性代数·动态规划·随机数学
季明洵3 天前
动态规划及背包问题
java·数据结构·算法·动态规划·背包问题