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

LeetCode 509. 斐波那契数

题目链接:509. 斐波那契数

踩坑:dp[0] = 0真就是第零个斐波那契数等于0,不是第一个。

思路:

确定dp数组的含义:dp[i]:第i个斐波那契数

递推公式:dp[i] = dp[i-1] + dp[i-2]

dp数组初始化:dp[0] = 0; dp[1] = 1

遍历顺序:从前往后

代码:

cpp 复制代码
class Solution {
public:
    int fib(int 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];
    }
};

LeetCode 70. 爬楼梯

题目链接:70. 爬楼梯

踩坑:在想怎么实现类似回溯的对所有组合的遍历。

思路:对于当前第n阶台阶,其一定是通过1阶或者2阶台阶上来的,换句话说就是从n-1阶跨1阶或者从n-2阶跨2阶上来的,所以到第n阶的方式 = 到n-1阶的方式 + 到n-2阶的方式。这里可以初始化dp[0] = 1; dp[1] = 1或者dp[1] = 1; dp[2] = 2;

代码:

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

LeetCode 746. 使用最小花费爬楼梯

题目链接:746. 使用最小花费爬楼梯

踩坑:以为从0开始和从1开始二选一,但其实是都可以。

思路:

dp数组的含义:dp[i]:到第 i 阶的最小花费

递推公式:dp[i] = min(dp[i-1]+cost[i-1], dp[i-2]+cost[i-2])

dp数组初始化:dp[0] = 0; dp[1] = 0;

遍历顺序:从前向后

代码:

cpp 复制代码
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(cost[i-1]+dp[i-1], cost[i-2]+dp[i-2]);
        }
        return dp.back();
    }
};
相关推荐
南境十里·墨染春水8 小时前
C++传记(面向对象)虚析构函数 纯虚函数 抽象类 final、override关键字
开发语言·c++·笔记·算法
2301_797172758 小时前
基于C++的游戏引擎开发
开发语言·c++·算法
有为少年9 小时前
告别“唯语料论”:用合成抽象数据为大模型开智
人工智能·深度学习·神经网络·算法·机器学习·大模型·预训练
比昨天多敲两行9 小时前
C++ 二叉搜索树
开发语言·c++·算法
Season4509 小时前
C++11之正则表达式使用指南--[正则表达式介绍]|[regex的常用函数等介绍]
c++·算法·正则表达式
Tisfy10 小时前
LeetCode 2839.判断通过操作能否让字符串相等 I:if-else(两两判断)
算法·leetcode·字符串·题解
问好眼10 小时前
《算法竞赛进阶指南》0x04 二分-1.最佳牛围栏
数据结构·c++·算法·二分·信息学奥赛
海海不瞌睡(捏捏王子)10 小时前
C++ 知识点概要
开发语言·c++
会编程的土豆10 小时前
【数据结构与算法】优先队列
数据结构·算法
minji...12 小时前
Linux 进程信号(二)信号的保存,sigset_t,sigprocmask,sigpending
linux·运维·服务器·网络·数据结构·c++·算法