LeetCode746:使用最小花费爬楼梯

题目描述

给你一个整数数组 cost ,其中 cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。一旦你支付此费用,即可选择向上爬一个或者两个台阶。

你可以选择从下标为 0 或下标为 1 的台阶开始爬楼梯。

请你计算并返回达到楼梯顶部的最低花费。


代码

cpp 复制代码
class Solution {
public:
    int minCostClimbingStairs(vector<int>& cost) {
        /*
            dp[i]的含义:表示达到第i+1个台阶最小的花费(下标从0开始)
            推导公式:dp[i] = min(dp[i-1]+cost[i-1],dp[i-2]+cost[i-2])
            初始化:dp[0] = 0, dp[1] = 0
            确定遍历顺序:从前向后
        */

        vector<int> dp(cost.size() + 1,0);
        for (int i = 2; i <= cost.size(); i++) {
            dp[i] = min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2]);
        }
        return dp[cost.size()];
    }
};

优化

cpp 复制代码
class Solution {
public:
    int minCostClimbingStairs(vector<int>& cost) {
        /*
            dp[i]的含义:表示达到第i+1个台阶最小的花费(下标从0开始)
            推导公式:dp[i] = min(dp[i-1]+cost[i-1],dp[i-2]+cost[i-2])
            初始化:dp[0] = 0, dp[1] = 0
            确定遍历顺序:从前向后
        */
        int a = 0, b = 0, sum = 0;
        for (int i = 2; i <= cost.size(); i++) {
            a = b;
            b = sum;
            sum = min(a + cost[i - 2],b + cost[i - 1]);
        }
        return sum;
    }
};
相关推荐
leiming68 小时前
C++ vector容器
开发语言·c++·算法
Xの哲學9 小时前
Linux流量控制: 内核队列的深度剖析
linux·服务器·算法·架构·边缘计算
yaoh.wang9 小时前
力扣(LeetCode) 88: 合并两个有序数组 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·双指针
LYFlied10 小时前
【每日算法】 LeetCode 56. 合并区间
前端·算法·leetcode·面试·职场和发展
艾醒11 小时前
大模型原理剖析——多头潜在注意力 (MLA) 详解
算法
艾醒11 小时前
大模型原理剖析——DeepSeek-V3深度解析:671B参数MoE大模型的技术突破与实践
算法
jifengzhiling11 小时前
零极点对消:原理、作用与风险
人工智能·算法
鲨莎分不晴12 小时前
【前沿技术】Offline RL 全解:当强化学习失去“试错”的权利
人工智能·算法·机器学习
XFF不秃头13 小时前
力扣刷题笔记-全排列
c++·笔记·算法·leetcode