前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【LEETCODE】模拟面试-120- Triangle

【LEETCODE】模拟面试-120- Triangle

作者头像
杨熹
发布2018-04-02 16:44:20
6320
发布2018-04-02 16:44:20
举报
文章被收录于专栏:杨熹的专栏杨熹的专栏
题目:

https://leetcode.com/problems/triangle/

Given a triangle, find the minimum path sum from top to bottom. Each step you may move to adjacent numbers on the row below.

For example, given the following triangle [ [2], [3,4], [6,5,7], [4,1,8,3] ] The minimum path sum from top to bottom is 11 (i.e., 2 + 3 + 5 + 1 = 11).

Note: Bonus point if you are able to do this using only O(n) extra space, where n is the total number of rows in the triangle.

题意:

Given a triangle, and this problem is to find the minimum sum from top to down layer, at each layer, for each point, it can only sum with its adjacent point.

分析:

Since that when we move to the next layer, the sum depends on the previous layer's choice, and each choice maybe called more than once, so it's better to use Dynamic Programming to deal with it.

If we solve it from top to down, it may require to build 2D matrix. So we can try from down to top.

  • Suppose the triangle has n layers.
  • We firstly initiate dp as equal to the last layer of triangle, so dp has 1*n dimension.
  • Then we move from (n-1)th layer upward, for each movement, we will compare and store the minimum choice for each point in this layer. That is:
  • At (n-1)th layer, for each i in this layer, find min(triangle[i]+dp[i], triangle[i]+dp[i+1]), then refresh dp[i] with the result.
  • So dp[i] denote that, till current time, when we move from down to current layer, the minimum so far for each point i in this layer.

图例

[Python]
代码语言:javascript
复制
class Solution(object):
    def minimumTotal(self, triangle):
        """
        :type triangle: List[List[int]]
        :rtype: int
        """
        
        n = len(triangle)
        
        dp = triangle[n-1]
        
        for i in range(n-2,-1,-1):
            for j in range(i+1):
                dp[j] = min( dp[j], dp[j+1] ) + triangle[i][j]
        
        return dp[0]
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016.08.17 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目:
  • 题意:
  • 分析:
  • [Python]
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档