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]
相关推荐
断剑zou天涯3 小时前
【算法笔记】从暴力递归到动态规划(二)
java·算法·动态规划
Miraitowa_cheems6 小时前
LeetCode算法日记 - Day 108: 01背包
数据结构·算法·leetcode·深度优先·动态规划
啊吧怪不啊吧12 小时前
算法王冠上的明珠——动态规划之斐波那契数列问题
大数据·算法·动态规划
G***66912 天前
算法设计模式:贪心与动态规划
算法·设计模式·动态规划
nju_spy2 天前
论文阅读 - 深度学习端到端解决库存管理问题 - 有限时间范围内的多周期补货问题(Management Science)
人工智能·深度学习·动态规划·端到端·库存管理·两阶段pto·多周期补货问题
Alex艾力的IT数字空间3 天前
设计既保持高性能又兼顾可移植性的跨平台数据结构
数据结构·分布式·算法·微服务·中间件·架构·动态规划
Kuo-Teng3 天前
LeetCode 198: House Robber
java·算法·leetcode·职场和发展·动态规划
多彩电脑3 天前
死循环逻辑检测
数据结构·python·算法·动态规划
Codeking__4 天前
动态规划算法经典问题——01背包问题
算法·动态规划
Kuo-Teng4 天前
LeetCode 118: Pascal‘s Triangle
java·算法·leetcode·职场和发展·动态规划