LeetCode 64. 最小路径和
2023-03-14 22:46:51 时间
题目地址(64. 最小路径和)
https://leetcode-cn.com/problems/minimum-path-sum/
题目描述
给定一个包含非负整数的 m x n 网格 grid ,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。
说明:每次只能向下或者向右移动一步。
示例 1:
输入:grid = [[1,3,1],[1,5,1],[4,2,1]]
输出:7
解释:因为路径 1→3→1→1→1 的总和最小。
示例 2:
输入:grid = [[1,2,3],[4,5,6]]
输出:12
提示:
m == grid.length
n == gridi.length
1 <= m, n <= 200
0 <= gridi <= 100
思路
DP动态规划记录每个点的值
代码
- 语言支持:Python3
Python3 Code:
class Solution:
def minPathSum(self, grid: [[int]]) -> int:
rowLen = len(grid[0])
colLen = len(grid)
countGrid = [[0]*rowLen for i in range(colLen)]#初始化统计步数矩阵
countGrid[0][0] = grid[0][0]
for i in range(1, rowLen):
countGrid[0][i] = countGrid[0][i-1] + grid[0][i]
for j in range(1, colLen):
countGrid[j][0] = countGrid[j-1][0] + grid[j][0]
# print(countGrid)
for i in range(1, rowLen):##每个步数元素,存储从左边和上边的最小值,再加上自身的值,为自己所在元素的最小步数
for j in range(1, colLen):
# print("{} {}".format(j, i))
countGrid[j][i] = min(countGrid[j][i-1], countGrid[j-1][i]) + grid[j][i]
return countGrid[colLen-1][rowLen-1]
if __name__ == '__main__':
# grid = [
# [1,3,1],
# [1,5,1],
# [4,2,1]
# ]
grid = [[1,2,5],[3,2,1]]
result = Solution().minPathSum(grid)
print(result)
复杂度分析
令 n 为数组长度。
- 时间复杂度:$O(n^2)$
- 空间复杂度:$O(n^2)$
相关文章
- 在 Go 里用 CGO?这 7 个问题你要关注!
- 9款优秀的去中心化通讯软件 Matrix 的客户端
- 求职数据分析,项目经验该怎么写
- 在OKR中,我看到了数据驱动业务的未来
- 火山引擎云原生大数据在金融行业的实践
- OpenHarmony富设备移植指南(二)—从postmarketOS获取移植资源
- 《数据成熟度指数》报告:64%的企业领袖认为大多数员工“不懂数据”
- OpenHarmony 小型系统兼容性测试指南
- 肯睿中国(Cloudera):2023年企业数字战略三大趋势预测
- 适用于 Linux 的十大命令行游戏
- GNOME 截图工具的新旧截图方式
- System76 即将推出的 COSMIC 桌面正在酝酿大变化
- 2GB 内存 8GB 存储即可流畅运行,Windows 11 极致精简版系统 Tiny11 发布
- 迎接 ecode:一个即将推出的具有全新图形用户界面框架的现代、轻量级代码编辑器
- loongarch架构介绍(三)—地址翻译
- Go 语言怎么解决编译器错误“err is shadowed during return”?
- 敏捷:可能被开发人员遗忘的部分
- Denodo预测2023年数据管理和分析的未来
- 利用数据推动可持续发展
- 在 Vue3 中实现 React 原生 Hooks(useState、useEffect),深入理解 React Hooks 的