当前位置: 首页 > news >正文

代码随想录Day32:动态规划(斐波那契数、爬楼梯、使用最小花费爬楼梯)

一、理论

什么是动态规划(Dynamic Programming)?如果某一问题有很多重叠子问题,使用动态规划是最有效的。动态规划中每一个状态一定是由上一个状态推导出来的,这一点就区分于贪心,贪心没有状态推导,而是从局部直接选最优的,而且很多讲解动态规划的文章都会讲最优子结构啊和重叠子问题啊这些,这些东西都是教科书的上定义,晦涩难懂而且不实用,知道动规是由前一个状态推导出来的,而贪心是局部直接选最优的,对于刷题来说就够用了

误区:状态转移公式(递推公式)只是一部分,必须掌握根本性的解题步骤。

对于动态规划问题,拆解为如下五步曲,这五步都搞清楚了,才能说把动态规划真的掌握了!

  1. 确定dp数组(dp table)以及下标的含义
  2. 确定递推公式
  3. dp数组如何初始化
  4. 确定遍历顺序
  5. 举例推导dp数组=打印dp数组

二、实战

509斐波那契数

509. 斐波那契数 - 力扣(LeetCode)

  • 确定dp数组(dp table)以及下标的含义dp[i]:第i个斐波那契数值
  • 确定递推公式:dp[i]=dp[i-1]+dp[i-2]
  • dp数组如何初始化根据题目描述,dp[0]=dp[1]=1
  • 确定遍历顺序必须从前向后遍历
  • 举例推导dp数组=打印dp数组:用来debug
package org.example.DP;public class fib509 {public int fib(int n) {//特殊情况if (n <= 1) return n;int[] dp=new int[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爬楼梯

70. 爬楼梯 - 力扣(LeetCode)

爬到第一层楼梯有一种方法,爬到二层楼梯有两种方法。那么第一层楼梯再跨两步就到第三层 ,第二层楼梯再跨一步就到第三层。所以到第三层楼梯的状态可以由第二层楼梯 和 到第一层楼梯状态推导出来,那么就可以想到动态规划了。

  • 确定dp数组(dp table)以及下标的含义dp[i]:第i个台阶有几种方法
  • 确定递推公式:dp[i]=dp[i-1]+dp[i-2]
  • dp数组如何初始化根据题目描述,dp[2]=2,dp[1]=1,这种定义更容易理解
  • 确定遍历顺序必须从前向后遍历
  • 举例推导dp数组=打印dp数组:用来debug
package org.example.DP;public class climbStairs70 {public int climbStairs(int n) {//特殊情况if (n <= 1) return n;int[] dp=new int[n+1];dp[2]=2;dp[1]=1;for(int i=2;i<=n;i++){dp[i]=dp[i-1]+dp[i-2];}return dp[n];}
}

或者初始为  dp[0]=1;dp[1]=1;也可以,但是不太好理解,这个就是为了得出结果倒退的dp[0]定义。

746使用最小花费爬楼梯

746. 使用最小花费爬楼梯 - 力扣(LeetCode)

  • 确定dp数组(dp table)以及下标的含义dp[i]:到第i个台阶的最小花费
  • 确定递推公式:dp[i]=min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2])
  • dp数组如何初始化根据题目描述,dp[2]=0,dp[1]=0,相当于 跳到 下标 0 或者 下标 1 是不花费体力的, 从 下标 0 下标1 开始跳就要花费体力了。
  • 确定遍历顺序必须从前向后遍历
  • 举例推导dp数组=打印dp数组:用来debug
package org.example.DP;public class minCostClimbingStairs746 {public int minCostClimbingStairs(int[] cost) {int n = cost.length;int[] dp = new int[n + 1];//从下标为 0 或下标为 1 的台阶开始,支付费用为0dp[0] = 0;dp[1] = 0;// 计算到达每一层台阶的最小费用for (int i = 2; i <= n; i++) {dp[i] = Math.min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2]);}return dp[n];}
}
http://www.lryc.cn/news/603036.html

相关文章:

  • 10:00开始面试,10:06就出来了,问的问题有点变态。。。
  • Jmeter 性能测试监控之ServerAgent
  • AT89C 系列单片机知识点总结
  • 基于VHDL的神经网络加速器设计实战
  • 基于亮数据 MCP 的 Trae 智能体,让规模化 Google 数据实时分析触手可及
  • DBAPI的SQL实现模糊查询的3种方案
  • git相关操作记录
  • C++初学者4——标准数据类型
  • Day 24:元组与os模块
  • STM32F4—电源管理器
  • 新华三H3CNE网络工程师认证—Telnet
  • 在 CentOS 中安装 MySQL 的过程与问题解决方案
  • 每日面试题16:什么是双亲委派模型
  • LINUX 728 SHELL:grep;sort;diff
  • mp核心功能
  • CDN架构全景图
  • 【JavaScript】箭头函数和普通函数的区别
  • 【AI论文】MegaScience:推动科学推理后训练数据集的前沿发展
  • Node.js + TypeScript 开发健壮的淘宝商品 API SDK
  • Flutter实现Android原生相机拍照
  • 项目任务如何分配?核心原则
  • MongoDB的内存和核心数对于运行效率的影响
  • Python动态规划:从基础到高阶优化的全面指南(2)
  • 商用车的自动驾驶应用场景主要包括七大领域
  • 代码随想录算法训练营第三十三天
  • C++模板进阶:从基础到实战的深度探索
  • 网易易盾、腾讯ACE等主流10款游戏反外挂系统对比
  • 7寸工业模组 XA070Y2-L01芯显科技详细参数资料
  • 图——邻接表基本操作算法实现
  • USRP X410 X440 5G及未来通信技术的非地面网络(NTN)