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];
    }
}
相关推荐
weixin_307779135 分钟前
基于Vosk与CTranslate2的实时语音识别翻译系统 —— 完整C++实现详解
人工智能·算法·自动化·语音识别·原型模式
akarinnnn8 分钟前
深入理解内存函数:原理、应用与优化
c语言·网络·数据结构·算法
一行代码一行诗++16 分钟前
for循环中的break和continue
数据结构·算法
Tisfy20 分钟前
LeetCode 3043.最长公共前缀的长度:哈希表(不转string)
算法·leetcode·散列表·题解·哈希表
代码中介商20 分钟前
排序算法完全指南(三):插入排序深度详解
算法·排序算法
承渊政道24 分钟前
【贪心算法】(经典实战应用解析(六):整数替换、俄罗斯套娃信封问题、可被三整除的最⼤和、距离相等的条形码、重构字符串)
c++·算法·leetcode·贪心算法·排序算法·动态规划·哈希算法
WL_Aurora27 分钟前
Python 算法基础篇之排序算法(二):希尔、快速、归并
python·算法·排序算法
闻缺陷则喜何志丹33 分钟前
【图论 树 启发式合并】P7165 [COCI2020-2021#1] Papričice|普及+
c++·算法·启发式算法·图论··洛谷
alexwang21134 分钟前
AT_abc458_d [ABC458D] Chalkboard Median题解
c++·算法·题解·atcoder
故事和你9135 分钟前
洛谷-【图论2-4】连通性问题1
开发语言·数据结构·c++·算法·动态规划·图论