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。

相关推荐
进击的荆棘8 小时前
优选算法——滑动窗口
c++·算法·leetcode
多米Domi0119 小时前
0x3f 第49天 面向实习的八股背诵第六天 过了一遍JVM的知识点,看了相关视频讲解JVM内存,垃圾清理,买了plus,稍微看了点确定一下方向
jvm·数据结构·python·算法·leetcode
VT.馒头1 天前
【力扣】2625. 扁平化嵌套数组
前端·javascript·算法·leetcode·职场和发展·typescript
毅炼1 天前
hot100打卡——day17
java·数据结构·算法·leetcode·深度优先
Tisfy1 天前
LeetCode 3010.将数组分成最小总代价的子数组 I:排序 OR 维护最小次小
算法·leetcode·题解·排序·最小次小值
草履虫建模1 天前
力扣算法 121. 买卖股票的最佳时机
算法·leetcode·职场和发展·贪心算法·动态规划·一次遍历
爱尔兰极光1 天前
LeetCode--有序数组的平方
算法·leetcode·职场和发展
haluhalu.1 天前
LeetCode---基础算法刷题指南
数据结构·算法·leetcode
iAkuya1 天前
(leetcode)力扣100 58组合总和(回溯)
算法·leetcode·职场和发展
爱尔兰极光1 天前
LeetCode--移除元素
算法·leetcode·职场和发展