动态规划:斐波那契形(初阶)

动态规划的常规解题步骤:

  • 状态表示
  • 状态转移方程
  • 初始化
  • 返回值

状态表示

我们写动态规划问题会创建一个名为dp的数组,也就是dp表。

状态表示就是dp表里面的值的含义。那么dp表是根据什么来创建的呢?

  • 1.题目要求
  • 2.经验
  • 3.分析问题的过程中,发现子问题。

状态转移方程

状态转移方程就是dp[i]等于什么,类似与数学中的方程表达式,比如dp[i]=dp[i-1]+dp[i-2]+dp[i-3];状态转移方程是动态规划的核心,也是最难点。

初始化

初始化的目的就是保证填dp表的时候不越界。

返回值

根据题目要求和状态转移方程返回符合题意的值

斐波那契型

斐波那契型就是当下的值与前一个或者前几个的值有关,所以状态转移方程经常是dp[i]=dp[i-1]+dp[i-2]+dp[i-3]等,或者是类似的变种。

例题

接下来我们以力扣的第1137题为例,来进行具体操作。

题目链接:https://leetcode.cn/problems/n-th-tribonacci-number/description/?envType=study-plan-v2&envId=dynamic-programming

代码:

java 复制代码
class Solution {
    public int tribonacci(int n) {
        //写dp表
        //初始化
        //状态表达式
        //处理边境
        //返回
        if(n==0)return 0;
        if(n==1 || n==2) return 1;
        int[] dp=new int[n+1];
        dp[0]=0;dp[1]=1;dp[2]=1;
        for(int i=3;i<n+1;i++){
            dp[i]=dp[i-1]+dp[i-2]+dp[i-3];
        }
        return dp[n];

    }
}

在此题中我们用dp[i]来表示第i个数的值,此为状态表示;

紧接着我们结合题意中,发现此题的状态转移方程非常简单,就是

dp[i]=dp[i-1]+dp[i-2]+dp[i-3];

由于出现了dp[i-3]所以我们需要初始化前三个数即可。

最终返回dp[n]。

拓展题

你学会了吗?接下来用以下这道题来检验一下吧:

题目链接放在这里了

https://leetcode.cn/problems/min-cost-climbing-stairs/description/?envType=study-plan-v2&envId=dynamic-programming

代码放在这里了

java 复制代码
class Solution {
    public int minCostClimbingStairs(int[] cost) {
        int n = cost.length;
        if (n == 0)
            return cost[0];
        if (n == 1)
            return Math.min(cost[0], cost[1]);
        int[] dp = new int[n + 1];
        dp[0] = cost[0];
        dp[1] = cost[1];

        for (int i = 2; i < n; i++) {
            dp[i] = Math.min(dp[i - 2], dp[i - 1]) + cost[i];
        }
        return Math.min(dp[n - 2], dp[n - 1]);
    }

}
相关推荐
小二·17 小时前
深入解析 Rust 并行迭代器:Rayon 库的原理与高性能实践
开发语言·算法·rust
国服第二切图仔17 小时前
Rust开发之错误处理与日志记录结合(log crate使用)
网络·算法·rust
ZHE|张恒18 小时前
LeetCode - 寻找两个正序数组的中位数
算法·leetcode
小龙报18 小时前
《算法通关指南算法千题篇(5)--- 1.最长递增,2.交换瓶子,3.翻硬币》
c语言·开发语言·数据结构·c++·算法·学习方法·visual studio
Cx330❀18 小时前
《C++ 多态》三大面向对象编程——多态:虚函数机制、重写规范与现代C++多态控制全概要
开发语言·数据结构·c++·算法·面试
_dindong18 小时前
【递归、回溯、搜索】专题六:记忆化搜索
数据结构·c++·笔记·学习·算法·深度优先·哈希算法
努力学算法的蒟蒻18 小时前
day03(11.1)——leetcode面试经典150
java·算法·leetcode
yugi98783818 小时前
C语言多进程创建和回收
linux·c语言·算法
极客数模18 小时前
【浅析赛题,一等奖水平】思路模型数据相关资料!2025 年“大湾区杯”粤港澳金融数学建模竞赛B 题 稳定币的综合评价与发展分析~
大数据·算法·数学建模·金融·数据挖掘·图论·1024程序员节
深入理解GEE云计算19 小时前
遥感生态指数(RSEI):理论发展、方法论争与实践进展
javascript·人工智能·算法·机器学习