Day32| 509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯

509. 斐波那契数

动态规划五部曲:

  1. 确定dp数组以及下标含义
  • 第i个数的斐波那契数列是dpi
  1. 确定递推公式
  • 状态转移方程 dpi = dpi - 1 + dpi - 2;
  1. dp数组如何初始化
  • dp0 = 0; dp1 = 1;
  1. 确定遍历顺序
  • dpi是依赖 dpi - 1 和 dpi - 2→遍历的顺序一定是从前到后遍历的
  1. 举例推导dp数组
cs 复制代码
public class Solution {
    public int Fib(int n) {
        if(n<2) return n;
        // 用长度为2的数组保存前两个结果,节省空间
        int[] dp=new int[2]{0,1};
        // 从 2 开始迭代直到 n
        for(int i=2;i<=n;i++){
            // 滚动数组:前一项变成现在的后一项
            int temp=dp[0]+dp[1];
            dp[0]=dp[1];
            dp[1]=temp;
        }
        // 返回第 n 项(最终保存在 dp[1] 中)
        return dp[1];
    }
}

70. 爬楼梯(写法与上题相同)

动态规划五部曲:

  1. 确定dp数组以及下标含义
  • 达到i阶有dpi种方法
  1. 确定递推公式
  • 状态转移方程 dpi = dpi - 1 + dpi - 2;
  1. dp数组如何初始化
  • dp1 = 1; dp2 = 2;
  1. 确定遍历顺序
  • dpi是依赖 dpi - 1 和 dpi - 2→遍历的顺序一定是从前到后遍历的
  1. 举例推导dp数组
cs 复制代码
public class Solution {
    public int ClimbStairs(int n) {
        if(n<=2) return n;
        int[] dp=new int[2]{1,2};
        for(int i=3;i<=n;i++){
            int temp=dp[0]+dp[1];
            dp[0]=dp[1];
            dp[1]=temp;
        }
        return dp[1];
    }
}

746. 使用最小花费爬楼梯

可以选择爬 1 或 2 个台阶,可以从下标 01 开始爬

动态规划五部曲:

  1. 确定dp数组以及下标含义
  • 到达第i台阶所花费的最少体力为dpi
  1. 确定递推公式
  • 状态转移方程

  • dpi=min(dpi-1+costi-1,dpi-2+costi-2

  1. dp数组如何初始化
  • dp0 = 0; / dp1 = 0;
  1. 确定遍历顺序
  • dpi是依赖 dpi - 1 和 dpi - 2→从前到后遍历cost数组
  1. 举例推导dp数组
cs 复制代码
public class Solution {
    public int MinCostClimbingStairs(int[] cost) {
        int[] dp=new int[2]{0,0};
        for(int i=2;i<=cost.Length;i++){
            int temp=Math.Min((dp[1]+cost[i-1]),(dp[0]+cost[i-2]));
            dp[0]=dp[1];
            dp[1]=temp;
        }
        return dp[1];
    }
}
相关推荐
洛水水2 分钟前
【力扣100题】87.只出现一次的数字
数据结构·算法·leetcode
HZ·湘怡2 分钟前
排序算法之希尔排序(2)--菜鸟先飞
数据结构·算法·排序算法·希尔排序
乐观勇敢坚强的老彭4 分钟前
2026全国青少年信息素养大赛(Python小学组)复赛复习讲义
python·算法·数学建模
林间码客13 分钟前
02数据挖掘:数据属性、类型与相似性度量
人工智能·算法·机器学习
阿标在干嘛14 分钟前
从“拍脑袋”到“数据驱动”:政策平台的A/B测试实践
大数据·人工智能·算法·ab测试
实在智能RPA18 分钟前
气象预警Agent等级判定算法:2026年AI驱动的概率集合预报与自动化闭环实践
人工智能·算法·ai·自动化
风筝在晴天搁浅1 小时前
LeetCode CodeTop 82.删除排序链表中的重复元素Ⅱ
算法·leetcode·链表
189228048611 小时前
NV114固态MT29F16T08EWLEHD6-MES:E
人工智能·算法·缓存·性能优化
Tairitsu_H1 小时前
[LC优选算法#4] 滑动窗口 | 串联所有单词的⼦串 | 最⼩覆盖⼦串
c++·算法·滑动窗口
devilnumber1 小时前
Java 二分查找(二分算法)详解 + 实战运用 + 核心坑点
java·开发语言·算法