最小路径和.java 1.9 KB
Newer Older
qq_36480062's avatar
commit  
qq_36480062 已提交
1
package dp;
qq_36480062's avatar
commit  
qq_36480062 已提交
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27

/**
 * https://mp.weixin.qq.com/s?__biz=MzUyNjQxNjYyMg==&mid=2247486923&idx=2&sn=6c1c8aeb4db68522e67ddf8c1e933660&chksm=fa0e624acd79eb5cdb410808921609a830b9b9221e813e4eb89cf551ca48f317668d44b095d2&scene=21#wechat_redirect
 * LeetCode 第 64 号问题最小路径和
 * 给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。
 * 说明:每次只能向下或者向右移动一步。
 * 示例:
 * 输入:
 * [
 * [1,3,1],
 * [1,5,1],
 * [4,2,1]
 * ]
 * 输出: 7
 * 解释: 因为路径 1→3→1→1→1 的总和最小。
 */
public class 最小路径和 {
    public static void main(String[] args) {
        int[][] arr = {{1, 3, 1}, {1, 5, 1}, {4, 2, 1}};

        System.out.println(zq(arr));
    }

    /**
     * dp[i][j]代表走到第i行,第j列,走过来的最小路径和,
     * dp[i][j] = Math.min(dp[i - 1][j] + dp[i][j - 1]) + arr[i][j]
qq_36480062's avatar
commit  
qq_36480062 已提交
28 29
     * 该递推方程代表,走到(i,j)的值,应当是(i-1,j)和(i,j-1)之间的较小值,
     * 再加上该位置的值,就是到(i,j)的最小路径和
qq_36480062's avatar
commit  
qq_36480062 已提交
30
     *
qq_36480062's avatar
c  
qq_36480062 已提交
31
     * @param grid 该数组
qq_36480062's avatar
commit  
qq_36480062 已提交
32 33
     * @return 最小路径和
     */
qq_36480062's avatar
c  
qq_36480062 已提交
34 35
    public static int zq(int[][] grid) {
        if (grid.length == 0 || grid[0].length == 0) return 0;
qq_36480062's avatar
commit  
qq_36480062 已提交
36
        //首先判断数组是不是为空
qq_36480062's avatar
c  
qq_36480062 已提交
37
        int m = grid.length, n = grid[0].length;
qq_36480062's avatar
commit  
qq_36480062 已提交
38 39 40
        int[][] dp = new int[m][n];

        {//基础条件代码块
qq_36480062's avatar
c  
qq_36480062 已提交
41
            dp[0][0] = grid[0][0];
qq_36480062's avatar
commit  
qq_36480062 已提交
42
            for (int i = 1; i < m; i++) {
qq_36480062's avatar
c  
qq_36480062 已提交
43
                dp[i][0] = grid[i][0] + dp[i - 1][0];
qq_36480062's avatar
commit  
qq_36480062 已提交
44 45
            }//初始化第一列
            for (int i = 1; i < n; i++) {
qq_36480062's avatar
c  
qq_36480062 已提交
46
                dp[0][i] = grid[0][i] + dp[0][i - 1];
qq_36480062's avatar
commit  
qq_36480062 已提交
47 48 49 50 51
            }//初始化第一行
        }

        for (int i = 1; i < m; i++) {
            for (int j = 1; j < n; j++) {
qq_36480062's avatar
c  
qq_36480062 已提交
52
                dp[i][j] = Math.min(dp[i - 1][j], dp[i][j - 1]) + grid[i][j];
qq_36480062's avatar
commit  
qq_36480062 已提交
53 54 55 56
            }
        }
        return dp[m - 1][n - 1];
    }
qq_36480062's avatar
commit  
qq_36480062 已提交
57
}