当前位置:首页 > 力扣 > LeetCode 120题三角形最小路径和最优解法:动态规划详解与代码实现

LeetCode 120题三角形最小路径和最优解法:动态规划详解与代码实现

10个月前 (06-14)

LeetCode 120题三角形最小路径和最优解法:动态规划详解与代码实现  三角形最小路径和 动态规划 自底向上递推 状态转移方程 第1张

一、题目解读

LeetCode 120题“三角形最小路径和”要求给定一个由数字组成的三角形,从顶部开始向下移动,每次可向左或向右移动一格,计算从顶至底的最小路径和。三角形以二维向量形式给出,每层元素数量递增,需找到所有可行路径中的最小值。该问题属于经典的动态规划应用场景,需通过合理设计状态转移方程来求解。

二、解题思路

采用动态规划策略,核心思想是自底向上递推。从三角形倒数第二层开始,逐层向上计算每个节点的最小路径和。关键在于利用下一层相邻节点的最小值,通过状态转移方程更新当前节点的值,最终得到顶点的最小路径和。该解法避免了暴力枚举所有路径,时间复杂度优化至O(n^2)(n为层数)。

三、解题步骤

1. 初始化:获取三角形层数n,确定递推起点为倒数第二层(i=n-2)。

2. 外层循环:从n-2到0层,逐层向上递推。

3. 内层循环:遍历当前层每个节点(0≤j≤i)。

4. 状态转移:当前节点的最小路径和 = 当前值 + 下一层相邻两个节点的较小值(即min(triangle[i+1][j], triangle[i+1][j+1]))。

5. 结果返回:最终顶层节点triangle[0][0]即为最小路径和。

四、代码与注释

#include <vector>
#include <algorithm>
using namespace std;

class Solution {
public:
    int minimumTotal(vector<vector<int>>& triangle) {
        int n = triangle.size();  // 获取层数
        // 从倒数第二层开始向上递推
        for (int i = n - 2; i >= 0; --i) {
            for (int j = 0; j <= i; ++j) {
                // 当前节点的最小路径和 = 当前值 + 下一层相邻两个节点的较小值
                triangle[i][j] += min(triangle[i+1][j], triangle[i+1][j+1]);
            }
        }
        return triangle[0][0];  // 返回顶点的最小路径和
    }
};

代码特点:

● 原地修改三角形数组,节省空间复杂度(O(1))。

● 利用min函数简化相邻节点比较,提升代码可读性。

五、总结

动态规划是解决此类路径优化问题的关键,需明确状态定义(每层节点的最小路径和)与转移方程。自底向上的递推方式避免了递归开销,且通过原地修改数组进一步优化资源消耗。在实际应用中,该思路可扩展至其他形路径问题,为算法设计提供通用框架。


原创内容 转载请注明出处

分享给朋友:

相关文章

牛客DP41精讲:当背包必须装满时,你的状态转移方程该如何调整?

牛客DP41精讲:当背包必须装满时,你的状态转移方程该如何调整?

题目重解我们面对一个经典背包问题的变体:给定n个物品,每个物品有重量w和价值v,背包容量为V。需要回答两个问题:1) 普通情况下能获得的最大价值;2) 必须恰好装满背包时的最大价值(若无法装满则输出0...

2024年GESP五级武器强化(洛谷B4071)解题代码C++版

2024年GESP五级武器强化(洛谷B4071)解题代码C++版

一、题目解读    2024年GESP(青少年软件编程能力等级考试)五级中的“武器强化”(洛谷平台题目编号B4071)是一道典型的算法优化问题。题目要求通过合理...

NOIP 2008火柴棒等式题解(C++代码实现)  动态规划与枚举算法详解

NOIP 2008火柴棒等式题解(C++代码实现) 动态规划与枚举算法详解

一、题目解读火柴棒等式问题(NOIP 2008,洛谷P1149)要求使用给定数量的火柴棒,构造形如 A + B = C 的等式,其中A、B、C均为整数,且火柴棒总数恰好等于输入值。需统计符合条件的等式...

洛谷P4999题解析:动态规划求解数字拆分与求和问题(附代码)

洛谷P4999题解析:动态规划求解数字拆分与求和问题(附代码)

一、题目解读洛谷P4999题要求处理给定区间 [L, R] 内数字的拆分与求和问题。每个数字需拆分为其各位数字之和,并计算区间内所有数字之和的累加结果。题目需考虑大数情况,并采用取模运算(MOD=1e...

牛客25461题解析:花园喷泉距离优化算法(动态规划+后缀数组解法)

牛客25461题解析:花园喷泉距离优化算法(动态规划+后缀数组解法)

一、题目解读牛客25461题要求计算一个花园中n朵花到两个喷泉的最小距离平方和。用户需输入喷泉坐标(x1,y1)和(x2,y2),以及n朵花的坐标(x,y),通过合理分配每朵花到两个喷泉的距离,使总距...

牛客网288555题解题指南:动态规划求解小红的暑假(附代码解析)

牛客网288555题解题指南:动态规划求解小红的暑假(附代码解析)

一、题目解读牛客网288555题要求解决一个组合数学问题:有三位朋友,每天需邀请其中一位参加聚会,但不能连续两天邀请同一位朋友。给定天数n,求满足条件的不同邀请方案总数。题目考察动态规划、状态转移及组...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。