当前位置:首页 > 力扣 > 力扣746:三步通关最小花费爬楼梯

力扣746:三步通关最小花费爬楼梯

4个月前 (05-16)

力扣746:三步通关最小花费爬楼梯 动态规划 算法 力扣 C++ 第1张

题目解析:

站在楼梯的某个台阶时,需要支付当前台阶对应的体力值cost[i],之后可以选择向上爬1或2个台阶。最终目标是到达‌楼层顶部‌(即数组末尾之后的位置),且初始位置可选择下标0或1的台阶作为起点。要求找出到达顶部的‌最小花费路径‌。例如输入cost=[10,15,20]时,最佳路径是从索引1出发直接跨两步到顶部,总花费15。


解题思路与过程:

1.关键逻辑拆解

    ‌状态定义‌:dp[i]表示到达索引i台阶时的最小累计花费。

‌    初始化设定‌:

        dp[0]=cost[0](必须支付cost[0]才能站在第0级)

        dp[1]=cost[1](同理必须支付cost[1]才能站在第1级)

        dp[2]=min(dp[0],dp[1])(到达索引2时可选前两步中更优路径)

2‌.循环递推‌:

    从i=3开始遍历到cost.size()(即楼梯顶部)

    ‌特殊处理i=3‌:当i-1 == 2时,说明当前处于索引3,此时比较前一步总花费+cost[i-1]与前两步总花费的最小值

    ‌一般情况‌:其他位置比较前一步总花费+cost[i-1]与前两步总花费+cost[i-2]


算法特点

‌1.反向递推终点‌:最终返回dp[cost.size()],该位置代表楼梯外的顶部,其值由前面的递推关系决定。

‌2.边界条件优化‌:通过提前处理dp[2]减少后续分支判断,但for循环内的条件语句增加了代码复杂度。


代码+注释:

class Solution {
public:
    int minCostClimbingStairs(vector<int>& cost) {
        int dp[1001]; // 假设cost长度<=1000,避免动态内存分配
        dp[0] = cost[0]; // 必须支付cost[0]才能站在第0级台阶
        dp[1] = cost[1]; // 同理,支付cost[1]后才能站在第1级
        dp[2] = min(dp[0], dp[1]); // 到达第2级的最小花费为前两步的较小值
        
        for(int i = 3; i <= cost.size(); i++) { // 从第3级开始推导到顶部
            if(i-1 != 2) { // 非特殊位置时的通用递推
                dp[i] = min(dp[i-1] + cost[i-1], dp[i-2] + cost[i-2]);
            } else { // 处理i=3时的特殊边界情况
                dp[i] = min(dp[i-1] + cost[i-1], dp[i-2]);
            }
        }
        return dp[cost.size()]; // 返回到达顶部的最小花费
    }
};


原创内容 转载请注明出处

分享给朋友:

相关文章

力扣第92题:三步定位 精准反转链表指定区间

力扣第92题:三步定位 精准反转链表指定区间

题目解读给定一个单链表和两个整数left与right,要求将链表中从第left个节点到第right个节点的部分进行反转,而保持其他部分不变。例如,对于链表1→2→3→4→5,left=2,right=...

IOI 1994 洛谷1216:如何用动态规划高效解决数字三角形问题?附完整代码解析

IOI 1994 洛谷1216:如何用动态规划高效解决数字三角形问题?附完整代码解析

题目重解给定一个由数字组成的三角形结构,从顶部出发,每次可以移动到下方相邻的数字,最终到达底部。我们的目标是找到一条路径,使得路径上经过的数字总和最大。这个问题在实际中有许多应用场景,如最优路径规划、...

力扣94:递归之美 轻松掌握二叉树中序遍历

力扣94:递归之美 轻松掌握二叉树中序遍历

题目解读二叉树的中序遍历是一种基础且重要的树遍历方式,其遍历顺序为:先递归地中序遍历左子树,然后访问根节点,最后递归地中序遍历右子树。对于二叉搜索树,中序遍历的结果恰好是节点值的升序排列。给定一个二叉...

CSP-J方格取数题解|动态规划解法|洛谷P7074代码解析

CSP-J方格取数题解|动态规划解法|洛谷P7074代码解析

一、题目解读题目要求在一个n×m的网格中,从左上角到右下角选择一条路径,路径上的数字可重复取用,求取数之和的最大值。路径限制为仅能向右或向下移动。需注意路径的灵活性与重复取数的可能性,传统单向动态规划...

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

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

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

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

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

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

发表评论

访客

看不清,换一张

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