zoukankan      html  css  js  c++  java
  • LeetCode 64. 最小路径和

    64. 最小路径和

    Difficulty: 中等

    给定一个包含非负整数的 _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 <= grid[i][j] <= 100

    Solution

    这个算是比较简单类型的动态规划题目了,题目要求从网格中找到一条从左上角到右下角的路径,并且每次只能向右或者向下移动,所以到达网格中grid[i][j]只会以下几种情况:

    1. 当i=0或j=0时,此时在网格的边缘处,此时只能向右或者只能向下移动
    2. 当i>0且j>0时,此时不在网格的边缘处,那么到达grid[i][j]可以是从它的上方或者左方方向,此时我们只需要取路径和较小的方向即可

    时间复杂度O(mn),没有使用额外的空间。

    class Solution:
        def minPathSum(self, grid: List[List[int]]) -> int:
            # m 矩阵行数 n 矩阵列数
            m, n = len(grid), len(grid[0])
            if m == 0 or n == 0:
                return 0
            for i in range(m):
                for j in range(n):
                    if i == 0 and j == 0:
                        continue
                    elif i > 0 and j == 0:
                        grid[i][j] += grid[i-1][j]
                    elif i == 0 and j > 0:
                        grid[i][j] += grid[i][j-1]
                    else:
                        grid[i][j] += min(grid[i-1][j],grid[i][j-1])
            return grid[m-1][n-1]
    

    相似题目:

    LeetCode 120. 三角形最小路径和 - swordspoet - 博客园

  • 相关阅读:
    iOS:网络检测
    WinJS:设置listView垂直滚动
    iOS:在AppDelegate中定义managed object context
    简笔画项目总结: ios绘图机制 & 实现记录笔迹功能
    CSS基础
    DOM小结
    iOS:view.frame
    WP:初探
    iOS:UIWebView scrollView 的分页滑动问题
    Mono for Android: 利用mono for android开发的第一个程序
  • 原文地址:https://www.cnblogs.com/swordspoet/p/14873256.html
Copyright © 2011-2022 走看看