[LeetCode]120. Triangle

[LeetCode]120. Triangle

题目描述这里写图片描述

思路

动归,新建一个状态保存数组

原数组状态数组
22
3 45 6
6 5 711 10 13
4 1 8 315 11 18 16

所以结果是11

代码

class Solution {
public:
    int minimumTotal(vector<vector<int>>& triangle) {
        vector<vector<int>> dp;
        dp.push_back(*triangle.begin());
        for (int i = 0; i < triangle.size() - 1; ++i) {
            vector<int> num = {};
            dp.push_back(num);
            for (int j = 0; j < triangle[i].size(); ++j) {
                if (j == 0) {
                    dp[i + 1].push_back(dp[i][j] + triangle[i + 1][j]);
                }
                else {
                    if(dp[i][j] + triangle[i + 1][j] < dp[i + 1][j])
                        dp[i + 1][j] =  dp[i][j] + triangle[i + 1][j];
                }
                dp[i + 1].push_back(dp[i][j] + triangle[i + 1][j + 1]);
            }
        }
        int min = dp[dp.size() - 1][0];
        for (auto &p : dp[dp.size() - 1]) {
            min = p < min ? p : min;
        }
        return min;
    }
};

更新

思路update

节省空间考虑
状态数组可以从下往上算

原数组状态数组
4 1 8 34 1 8 3
6 5 77 6 10
3 49 10
211

代码update

class Solution {
public:
    int minimumTotal(vector<vector<int>>& triangle) {
        int len = triangle.size();
        vector<int> dp(triangle[len - 1].begin(), triangle[len - 1].end());
        for (int i = len - 2; i >= 0; --i)
            for (int j = 0; j < i + 1; ++j)
                dp[j] = triangle[i][j] + min(dp[j], dp[j + 1]);

        return dp[0];
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值