Leetcode 3418. Maximum Amount of Money Robot Can Earn

  • [Leetcode 3418. Maximum Amount of Money Robot Can Earn](#Leetcode 3418. Maximum Amount of Money Robot Can Earn)
    • [1. 解题思路](#1. 解题思路)
    • [2. 代码实现](#2. 代码实现)

1. 解题思路

这一题我的思路比较暴力,就是一个动态规划,本质上就是全量遍历,然后找到最优路径。

2. 代码实现

给出python代码实现如下:

python 复制代码
class Solution:
    def maximumAmount(self, coins: List[List[int]]) -> int:
        n, m = len(coins), len(coins[0])
        
        @lru_cache(None)
        def dp(i, j, k):
            if i == n-1 and j == m-1:
                return coins[i][j] if (coins[i][j] >= 0 or k == 0) else 0
            ans = -math.inf
            if coins[i][j] >= 0 or k == 0:
                if i+1 < n:
                    ans = max(ans, coins[i][j] + dp(i+1, j, k))
                if j+1 < m:
                    ans = max(ans, coins[i][j] + dp(i, j+1, k))
            else:
                if i+1 < n:
                    ans = max(ans, coins[i][j] + dp(i+1, j, k), dp(i+1, j, k-1))
                if j+1 < m:
                    ans = max(ans, coins[i][j] + dp(i, j+1, k), dp(i, j+1, k-1))
            return ans
        
        return dp(0, 0, 2)

提交代码评测得到:耗时4833ms,占用内存576.6MB。

相关推荐
smj2302_7968265218 小时前
解决leetcode第3753题范围内总波动值II
python·算法·leetcode
leoufung21 小时前
LeetCode 92 反转链表 II 全流程详解
算法·leetcode·链表
利刃大大1 天前
【动态规划:背包问题】完全平方数
c++·算法·动态规划·背包问题·完全背包
im_AMBER1 天前
Leetcode 59 二分搜索
数据结构·笔记·学习·算法·leetcode
leoufung1 天前
LeetCode 61. 旋转链表(Rotate List)题解与思路详解
leetcode·链表·list
leoufung1 天前
逆波兰表达式 LeetCode 题解及相关思路笔记
linux·笔记·leetcode
Aspect of twilight1 天前
LeetCode华为大模型岗刷题
python·leetcode·华为·力扣·算法题
2301_807997381 天前
代码随想录-day47
数据结构·c++·算法·leetcode
Elias不吃糖1 天前
LeetCode每日一练(3)
c++·算法·leetcode
醉颜凉1 天前
环形房屋如何 “安全劫舍”?动态规划解题逻辑与技巧
c语言·算法·动态规划