LeetCode 第38天 | 初识动态规划 509.斐波那契数列 70.爬楼梯 746.使用最小花费爬楼梯

509. 斐波那契数
递推关系已经给出来了,即f(n) = f(n-1) + f(n-2);初始化dp也已经给出,即dp[0] = 0,dp[1] = 1,注意第n个位置需要定义dp[n+1]大小的数组。最终结果就是dp[n]。

cpp 复制代码
class Solution {
public:
    int fib(int n) {
        if (n == 0 || 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. 爬楼梯
比斐波那契难一点,但是也有迹可循。一次只能爬两蹬或者一蹬,那么本台阶可由上一阶爬来,也可由上上阶爬来,因此其和即为本蹬数量。而本蹬数量取决于上两凳,因此形成递推关系。dp大小也为n+1。

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

57. 爬楼梯(第八期模拟笔试)
卡码网中的题目。如果题目改为一次可爬1------n怎么解,其实本阶梯可由前n级阶梯到达(如果有的话)。那么就可以两层循环解决。

cpp 复制代码
#include<iostream>
#include<vector>
using namespace std;
int main() {
    int n,m;
    cin>>n>>m;
    std::vector<int> dp(n+1,0);
    dp[0] = 1;
    for (int i = 1; i<=n; i++) {
        for (int j = 1; j<=m; j++) {
            // 向前找m个位置,各个位置都可以到达i,因此累加前面的结果
            if (i-j >= 0) dp[i] += dp[i-j];
        }
    }
    cout<<dp[n];
}

746. 使用最小花费爬楼梯
这题出发点可以是0也可以是1,因此从零出发和从1出发都不需要消耗体力。dp数组可以初始化为0。而本台阶可以由上一个台阶爬到,消耗体力x,也可以由上上个台阶爬到,消耗体力y;则达到本台阶消耗的最小体力为min(dp[i-1]+cost[i-1], dp[i-2]+cost[i-2])。注意最后需要爬到房顶,因此dp大小n+1。

cpp 复制代码
    class Solution {
    public:
        int minCostClimbingStairs(vector<int>& cost) {
            vector<int> dp(cost.size()+1);
            // 可以从0 也可以从1出发,那么初始化0 和 1位置为0消耗
            dp[0] = 0;
            dp[1] = 0;
            // 需要爬到楼顶, 因此i的值需要最终等于cost的大小
            for (int i = 2; i <= cost.size(); i++) {
                dp[i] = min(dp[i-2] + cost[i-2], dp[i-1] + cost[i-1]);
            }
            // 返回dp数组的最后一个值即为结果
            return dp[cost.size()];
        }
    };
相关推荐
生成论实验室15 小时前
《事件关系阴阳博弈动力学:识势应势之道》第二篇:阴阳博弈——认知的动力学基础
数据结构·人工智能·科技·神经网络·算法
风筝在晴天搁浅16 小时前
字节高频题 小于n的最大数
算法
LabVIEW开发16 小时前
LabVIEW水力机组空蚀在线监测
算法·labview·labview知识·labview功能·labview程序
AI科技星16 小时前
科幻艺术书本封面:《全域数学》第一部·数术本源 第三卷 代数原本(P95-141)完整五级目录【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
风筝在晴天搁浅16 小时前
LeetCode 92.反转链表Ⅱ
算法·leetcode·链表
王老师青少年编程16 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【贪心与二分判定】:数列分段 Section II
c++·算法·贪心·csp·信奥赛·二分判定·数列分段 section ii
V搜xhliang024616 小时前
OpenClaw科研全场景用法:从文献到实验室的完整自动化方案
运维·开发语言·人工智能·python·算法·microsoft·自动化
汉克老师17 小时前
GESP2025年3月认证C++五级( 第三部分编程题(2、原根判断))
c++·算法·模运算·gesp5级·gesp五级·原根·分解质因数
数据皮皮侠17 小时前
上市公司创新韧性数据(2000-2024)|顶刊同款 EIR 指数
大数据·人工智能·算法·智慧城市·制造
WL_Aurora17 小时前
Python 算法基础篇之链表
python·算法·链表