首页 > 其他 > 详细

[LeetCode] 64.最小路径和

时间:2020-04-04 01:17:16      阅读:67      评论:0      收藏:0      [点我收藏+]

   第一个:

class Solution {
    public int minPathSum(int[][] m) {
        if(m==null||m.length==0||m[0]==null||m[0].length==0){
            return 0;
        }

        int row=m.length;
        int col=m[0].length;
        int[][] dp=new int[row][col];
        dp[0][0] = m[0][0];
        for(int i=1;i<row;i++){
            dp[i][0]=dp[i-1][0]+m[i][0];
        }
        for(int i=1;i<col;i++){
            dp[0][i]=dp[0][i-1]+m[0][i];
        }
        for(int i=1;i<row;i++){
            for(int j=1;j<row;j++){
                dp[i][j] = Math.min(dp[i - 1][j], dp[i][j - 1]) + m[i][j];
            }
        }
        return dp[row - 1][col - 1];
    }
}

技术分享图片

 

 第二种:把dp数组换成一维的

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

技术分享图片

 

[LeetCode] 64.最小路径和

原文:https://www.cnblogs.com/doyi111/p/12630040.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!