码迷,mamicode.com
首页 > 其他好文 > 详细

leetCode 64.Minimum Path Sum (最短路) 解题思路和方法

时间:2015-07-17 19:03:12      阅读:109      评论:0      收藏:0      [点我收藏+]

标签:leetcode   动态规划   

Given a m x n grid filled with non-negative numbers, find a path from top left to bottom right which minimizes the sum of all numbers along its path.

Note: You can only move either down or right at any point in time.


思路:此题和前面几个机器人的题非常相像,只是变化了一点,具体代码和注释如下:

public 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)//分三种情况,第二行第二列之后
                    grid[i][j] += Math.min(grid[i-1][j],grid[i][j-1]);
                else if(i == 0 && j > 0)//第一行
                    grid[i][j] += grid[i][j-1];
                else if(i > 0 && j==0)//第一列
                    grid[i][j] += grid[i-1][j];
            }
        //返回最后一个值
        return grid[grid.length-1][grid[0].length-1];
    }
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

leetCode 64.Minimum Path Sum (最短路) 解题思路和方法

标签:leetcode   动态规划   

原文地址:http://blog.csdn.net/xygy8860/article/details/46929163

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!