前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >关关的刷题日记96 – Leetcode 120. Triangle

关关的刷题日记96 – Leetcode 120. Triangle

作者头像
WZEARW
发布2018-04-12 17:47:37
5640
发布2018-04-12 17:47:37
举报
文章被收录于专栏:专知专知

关关的刷题日记96 – Leetcode 120. 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.

给定一个三角形,找到从顶端到低端的最小路径和。每一次可以移动到下一排的相邻的数。能否实现只需要O(n)空间复杂度的算法,n为三角的行数。

思路

对于每一个点来说,以其为端点的路径要么是从左上点下来的,要么是从右上点下来的,所以以这点为端点的路径和sum[i][j]=min(sum[i-1][j-1], sum[i-1][j])+这点值,采用动规的方法来做。

代码语言:javascript
复制
class Solution {
public:
    int minimumTotal(vector<vector<int>>& triangle) {
        int re=INT_MAX;
        for(int i=1; i<triangle.size(); ++i)
        {
            for(int j=0; j<triangle[i].size(); ++j)
            {
                if(j==0)
                    triangle[i][j]=triangle[i-1][j]+triangle[i][j];
                else if(j==i)
                    triangle[i][j]=triangle[i-1][j-1]+triangle[i][j];
                else
                    triangle[i][j]=min(triangle[i-1][j-1],triangle[i-1][j])+triangle[i][j];
            }
        }
        for(int i=0; i<triangle[triangle.size()-1].size(); ++i)
            re=min(re,triangle[triangle.size()-1][i]);
        return re<INT_MAX?re:0;
    }
};

人生易老,唯有陪伴最长情,加油!

以上就是关关关于这道题的总结经验,希望大家能够理解,有什么问题可以在我们的专知公众号平台上交流或者加我们的QQ专知-人工智能交流群 426491390,也可以加入专知——Leetcode刷题交流群(请先加微信小助手weixinhao: Rancho_Fang)。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-01-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 专知 微信公众号,前往查看

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

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

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