Lintcode110 Minimum Path Sum solution 题解

【题目描述】

Given amxngrid filled with non-negative numbers, find a path from top left to bottom right whichminimizesthe sum of all numbers along its path.

给定一个只含非负整数的m*n网格,找到一条从左上角到右下角的可以使数字和最小的路径。

【注】:你在同一时间只能向下或者向右移动一步

【题目链接】

www.lintcode.com/en/problem/minimum-path-sum/

【题目解析】

本题是动态规划基本的基本类型。该题的思想是建立f[i][j],表示从起点到f[i][j]最小权值。

由于(i,j)只能由(i-1,j)和(i,j-1)两个点到达,假设我们已经知道了f[i-1][j]和f[i][j-1],则f[i][j]的最小值等于min(f[i-1][j], f[i][j - 1])加上当前(i,j)的权值,即:

f[i][j] = g[i][j] + min(f[i - 1][j], f[i][j - 1])

所以我们通过行列的递推,就能够得到从左上角到右下角的最小权值f[m][n],时间复杂度为O(mn)。

【参考答案】

www.jiuzhang.com/solutions/minimum-path-sum/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,354评论 0 33
  • 动态规划(Dynamic Programming) 本文包括: 动态规划定义 状态转移方程 动态规划算法步骤 最长...
    廖少少阅读 8,861评论 0 18
  • 回溯算法 回溯法:也称为试探法,它并不考虑问题规模的大小,而是从问题的最明显的最小规模开始逐步求解出可能的答案,并...
    fredal阅读 14,693评论 0 89
  • ios8发布已经有一段时间了,伴随着ios8同时也出现了许多新的特性,ios系统将会越来越开放,这是好事。其中一个...
    Gatling阅读 3,251评论 0 2
  • 孩子是不能欺骗的。孩子年纪小,不懂世事,只得学习别人的样子,尤其是以父母作为生活的榜样。今天你欺骗了孩子,玷污了他...
    好听的暖阳阅读 3,089评论 10 4