LeetCode热题100--64. 最小路径和--中等

题目

给定一个包含非负整数的 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

题解

java 复制代码
class Solution {
    public int minPathSum(int[][] grid) {
        for(int i = 0; i < grid.length; i++) {
            for(int j = 0; j < grid[0].length; j++) {
                if(i == 0 && j == 0) continue;
                else if(i == 0)  grid[i][j] = grid[i][j - 1] + grid[i][j];
                else if(j == 0)  grid[i][j] = grid[i - 1][j] + grid[i][j];
                else grid[i][j] = Math.min(grid[i - 1][j], grid[i][j - 1]) + grid[i][j];
            }
        }
        return grid[grid.length - 1][grid[0].length - 1];
    }
}

解析

出自:最小路径和 (动态规划,规范流程,清晰图解)

java 复制代码
class Solution {
    public int minPathSum(int[][] grid) {
        // 遍历网格的每一行(从上到下)
        for (int i = 0; i < grid.length; i++) {
            // 遍历当前行的每一列(从左到右)
            for (int j = 0; j < grid[0].length; j++) {
                // 起点 (0,0):路径和就是它本身,无需更新
                if (i == 0 && j == 0) continue;
                // 第一行(只能从左边来):累加左侧格子的最小路径和
                else if (i == 0) grid[i][j] = grid[i][j - 1] + grid[i][j];
                // 第一列(只能从上面来):累加上方格子的最小路径和
                else if (j == 0) grid[i][j] = grid[i - 1][j] + grid[i][j];
                // 其他位置:取上方和左方的较小值,加上当前格子的值
                else grid[i][j] = Math.min(grid[i - 1][j], grid[i][j - 1]) + grid[i][j];
            }
        }
        // 返回右下角的值,即从左上到右下的最小路径和
        return grid[grid.length - 1][grid[0].length - 1];
    }
}
相关推荐
南境十里·墨染春水5 小时前
C++ 工厂模式:从入门到进阶,彻底掌握对象创建的艺术
开发语言·c++·算法
@insist1235 小时前
系统架构设计师-实时性评价、调度算法与内核架构选型
算法·架构·系统架构·软考·系统架构设计师·软件水平考试
一只齐刘海的猫11 小时前
【Leetcode】找到字符串中所有字母异位词
算法·leetcode·职场和发展
海清河晏11111 小时前
数据结构 | 八大排序
数据结构·算法·排序算法
IronMurphy12 小时前
【算法五十七】146. LRU 缓存
算法·缓存
文艺倾年13 小时前
【强化学习】强化学习基本概念,20W字总结(一)
人工智能·python·语言模型·自然语言处理·面试·职场和发展·大模型
凌波粒13 小时前
LeetCode--108.将有序数组转换为二叉搜索树(二叉树)
算法·leetcode·职场和发展
liulilittle13 小时前
KCC:在 BBR 思路上的一次探索
网络·tcp/ip·算法·bbr·通信·拥塞控制·kcc
浦信仿真大讲堂13 小时前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍
人工智能·python·算法·仿真软件·达索软件