算法通关村第十九关——最小路径和

LeetCode64. 给定一个包含非负整数的 m × n 网格 grid,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。

输入:grid=\[1,3,1,1,5,1,4,2,1]

输出:7

解释:因为路径1→3→1→1→1的总和最小。

复制代码
public int minPathSum(int[][] grid) {
    int m = grid.length, n = grid[0].length;
    int[][] f = new int[m][n];
    for (int i = 0; i < m; i++) {
        for (int j = 0; j < n; j++) {
            if (i == 0 && j == 0) {
                f[i][j] = grid[i][j];
            } else {
                int top = i - 1 >= 0 ? f[i - 1][j] + grid[i][j] : Integer.MAX_VALUE;
                int left = j - 1 >= 0 ? f[i][j - 1] + grid[i][j] : Integer.MAX_VALUE;
                f[i][j] = Math.min(top, left);
            }
        }
    }
    return f[m - 1][n - 1];
}

对于每一块方块来说,只能从他的上边或者左边走过来,所以在for循环中的要取上边过来的和左边过来的最小的。

并且在dp中的二维数组中每一个位置存放的都是到当前位置的最小路径和。

相关推荐
南境十里·墨染春水21 小时前
数据结构 --- 红黑树
数据结构
sheeta199821 小时前
LeetCode 补拙笔记 日期:2026.06.07 题目:128. 最长连续序列
笔记·算法·leetcode
sheeta199821 小时前
LeetCode 补拙笔记 日期:2026.06.07 题目:1. 两数之和
笔记·算法·leetcode
柒和远方1 天前
LeetCode 452. 用最少数量的箭引爆气球 —— 区间贪心经典:排序 + 扫描一箭穿心
javascript·python·算法
Zhang~Ling1 天前
C++ 红黑树封装:myset和mymap的底层实现
开发语言·数据结构·c++·算法
ECT-OS-JiuHuaShan1 天前
什么是对和错?——“有针对性定义域的逻辑值的真伪”:认识论终极追问的公理化裁决
数据库·人工智能·算法·机器学习·数学建模
啦啦啦啦啦zzzz1 天前
数据结构:堆排序
数据结构·c++·
Merlyn101 天前
【栈】155. 最小栈
python·算法
一个不知名程序员www1 天前
算法学习入门---算法题DAY5
c++·算法