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;
    }
};
相关推荐
不会学习?29 分钟前
算法03 归并分治
算法
NuyoahC1 小时前
笔试——Day43
c++·算法·笔试
2301_821919921 小时前
决策树8.19
算法·决策树·机器学习
秋难降2 小时前
别再用暴力排序了!大小顶堆让「取极值」效率飙升至 O (log n)
python·算法·排序算法
学行库小秘2 小时前
基于门控循环单元的数据回归预测 GRU
人工智能·深度学习·神经网络·算法·回归·gru
_meow_3 小时前
数学建模 15 逻辑回归与随机森林
算法·数学建模·逻辑回归
1白天的黑夜13 小时前
链表-24.两两交换链表中的结点-力扣(LeetCode)
数据结构·leetcode·链表
二向箔reverse3 小时前
机器学习算法核心总结
人工智能·算法·机器学习
猿究院--冯磊4 小时前
JVM垃圾收集器
java·jvm·算法
野犬寒鸦5 小时前
力扣hot100:最大子数组和的两种高效方法:前缀和与Kadane算法(53)
java·后端·算法