【刷题】代码随想录算法训练营第三十八天|509、斐波那契数,70、爬楼梯,746、使用最小花费爬楼梯

目录

509、斐波那契数

讲解:https://programmercarl.com/0509.斐波那契数.html

动规是由前一个状态推导出来的,而贪心是局部直接选最优的,对于刷题来说就够用了。

复制代码
class Solution {
public:
    int fib(int n) {
        if(n<=1) return n;
        vector<int> dp(n+1);
        dp[0] = 0;
        dp[1] = 1;
        for (int i=2;i<=n;i++){
            dp[i] = dp[i-1] + dp[i-2];
        }
        return dp[n];
    }
};

70、爬楼梯

讲解:https://programmercarl.com/0070.爬楼梯.html

c 复制代码
class Solution {
public:
    int climbStairs(int n) {
        if (n <= 1) return n; // 因为下面直接对dp[2]操作了,防止空指针
        vector<int> dp(n + 1);
        dp[1] = 1;
        dp[2] = 2;
        for (int i = 3; i <= n; i++) { // 注意i是从3开始的
            dp[i] = dp[i - 1] + dp[i - 2];
        }
        return dp[n];
    }
};

746、使用最小花费爬楼梯

讲解:https://programmercarl.com/0746.使用最小花费爬楼梯.html

c 复制代码
class Solution {
public:
    int minCostClimbingStairs(vector<int>& cost) {
        vector<int> dp(cost.size()+1);
        dp[0] = 0;
        dp[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()];
    }
};
相关推荐
地平线开发者5 分钟前
智能驾驶中预测模块简介
算法·自动驾驶
小森77676 分钟前
(八)PMSM驱动控制学习---无感控制之滑膜观测器
算法·嵌入式·电机控制·foc·永磁同步电机·滑模控制
雾里看山9 分钟前
算法思想之双指针(二)
算法·推荐算法
地平线开发者10 分钟前
征程 6|工具链 VP 示例中日志打印解读
算法·自动驾驶
飞川00118 分钟前
【LeetCode 热题100】146:LRU 缓存(详细解析)(Go语言版)
算法
uhakadotcom25 分钟前
Supervised Fine-Tuning(SFT)最佳实践
算法·面试·github
2301_794461571 小时前
详解七大排序
数据结构·算法·排序算法
爱coding的橙子2 小时前
蓝桥杯备赛 Day16 单调数据结构
数据结构·c++·算法·蓝桥杯
wuqingshun3141592 小时前
经典算法 约数之和
数据结构·c++·算法·蓝桥杯
溟洵2 小时前
【C/C++算法】蓝桥杯之递归算法(如何编写想出递归写法)
c语言·c++·算法