代码随想录算法训练营Day38 || leetCode 7509. 斐波那契数 || 70. 爬楼梯 || 746. 使用最小花费爬楼梯

动态规划和我们数电中学习的时序电路类似,某一时刻的状态不仅与当前时刻的输入有关,还与之前的状态有关,所以推导过程中我们需要模拟题目中的情况,来找到每一时刻状态间的关系。
做题思路如下

509. 斐波那契数

此题简单

状态方程为dpi=dpi-1+dp2

初始状态dp0=0,dp1=1

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

70. 爬楼梯

仔细分析一下就会发现,此题本质也是斐波那契数列

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

746. 使用最小花费爬楼梯

首先小于两层的楼梯可以看作是无花费的,于是从第二层楼梯看起

因为求最小花费,且每次都可爬一到两层

所以dpi=min (dpi-1+costi-1,dpi-2+costi-2)

由此找到关系写代码即可

cpp 复制代码
class Solution {
public:
    int minCostClimbingStairs(vector<int>& cost) {
        int n = cost.size();
        vector<int> dp(n+1,0);
        for(int i = 2; i <= n; i++){
            dp[i] = min (dp[i-1]+cost[i-1],dp[i-2]+cost[i-2]);
        }
        return dp[n];
    }
};
相关推荐
Kurisu575几秒前
深度拆解:从二进制切片到并发控制,大文件断点续传的底层工程设计
算法
随意起个昵称34 分钟前
线性dp-LIS题目2(导弹拦截III)
算法·动态规划·图论
地平线开发者1 小时前
工具链使用从入门到顺手
算法
明航咨询—张老师1 小时前
AI工具狂飙时代:三款实用AI产品深度横向测评
大数据·人工智能·算法·it
医用门1 小时前
医院钢制门厂家有哪些品牌好的
leetcode
li星野2 小时前
FAISS 详解:原理、使用与面试指南——向量检索的基石
面试·职场和发展·faiss
mifengxing2 小时前
LeetCode热题100——字母异位词分组
java·算法·leetcode·职场和发展·哈希表·hot100
Billlly2 小时前
莫比乌斯反演学习笔记
算法
stolentime3 小时前
CF2066D1 Club of Young Aircraft Builders (easy version)题解
c++·算法·动态规划·组合数学
Dillon Dong3 小时前
【风电控制】高低穿现场失败的原因分析——算法简单但工程复杂
算法·变流器·风电控制·dfig