一、题目粗心

标签: 动静布局

https://leetcode.cn/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 == grid[i].length
  • 1 <= m, n <= 200
  • 0 <= gridi <= 100

二、解题思路

二维的动静规定,定义一个二维dp数组,其中dpi示意从左上角开始到(i, j)地位的最优门路的数字和。因为每次只能向下或者向右挪动,咱们能够失去状态转移方程dpi = min(dpi-1, dpi) + gridi。

三、解题办法

3.1 Java实现

public class Solution {    public int minPathSum(int[][] grid) {        int m = grid.length;        int n = grid[0].length;        int[][] dp = new int[m][n];        // dp[i][j] = min(dp[i-1][j], dp[i][j-1]) + grid[i][j]        dp[0][0] = grid[0][0];        for (int x = 0; x < m; x++) {            for (int y = 0; y < n; y++) {                if (x == 0 && y == 0) {                    dp[x][y] = grid[x][y];                } else if (x == 0) {                    dp[x][y] = dp[x][y-1] + grid[x][y];                } else if (y == 0) {                    dp[x][y] = dp[x-1][y] + grid[x][y];                } else {                    dp[x][y] = Math.min(dp[x-1][y], dp[x][y-1]) + grid[x][y];                }            }        }        return dp[m - 1][n - 1];    }}

四、总结小记

  • 2022/6/18 来到电商就对618无感了