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

代码随想录算法训练营第四十一天 | 理论基础、509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯

理论基础

代码随想录

视频:从此再也不怕动态规划了,动态规划解题方法论大曝光 !| 理论基础 |力扣刷题总结| 动态规划入门_哔哩哔哩_bilibili

动归五部曲 

1.dp数组以及下标的含义

2.递推公式

3.dp数组如何初始化

4.遍历顺序(例如先背包再物品,先物品再背包)

5.打印dp数组

509. 斐波那契数

代码随想录

视频:手把手带你入门动态规划 | LeetCode:509.斐波那契数_哔哩哔哩_bilibili

解题思路

1.确定dp[i]含义, dp[i]表示第i个斐波那契数的值

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

3.dp数组如何初始化 dp[0] = 1 , dp[1] = 1

4.确定遍历顺序,从前往后

class Solution {
public:int fib(int n) {if(n<=1) return n;vector<int> dp(n+1);   //0到n一共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.爬楼梯)| 动态规划经典入门题目_哔哩哔哩_bilibili

解题思路

到几阶,之前需要看前两阶的方法,第前2阶垮两步即可,第前1阶垮一步即可,所以就是前两阶的方法种数相加

1.dp[i] 达到第i阶楼梯有dp[i]种方法

2. 根据分析 dp[i] = dp[i-1] + dp[i-2]

3.初始化 d[1] = 1

dp[2] = 2

4.从前往后,(递推公式中相加的两个数都是经过计算的)

 

class Solution {
public:int climbStairs(int n) {if(n<=1) return n;  //防止空指针vector<int> dp(n+1);dp[1] = 1;dp[2] = 2;for(int i=3 ; i<=n ; i++){dp[i] = dp[i-1] + dp[i-2];}return dp[n];}
};

746. 使用最小花费爬楼梯

代码随想录

视频讲解:动态规划开更了!| LeetCode:746. 使用最小花费爬楼梯_哔哩哔哩_bilibili

解题思路

1.dp[i] 表示到达第i个台阶所消耗的最少体力

2. dp[i]可以由dp[i-1]+ cost[i-1]和dp[i-2] + cost[i-2]得到,取最小值即可 

3.初始化选择初始台阶时,不需要花费体力,只有跳才会花费,因此dp0和1都是0

4.遍历顺序:从前往后,因为都是由前面的台阶跳上来的

 

class Solution {
public:int minCostClimbingStairs(vector<int>& cost) {int n = cost.size();vector<int> dp(n+1);dp[0] = 0;dp[1] = 0;  //选择下标1或者0作为起始,没有体力花费,只有跳了才有花费for(int i=2 ; i < n+1 ; i++){dp[i] = min( dp[i-1] + cost[i-1], dp[i-2] + cost[i-2]);}return dp[n];}
};

收获

终于开始动规了,加油

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 记一次绕过宝塔防火墙的BC站渗透
  • 美颜技术揭秘:美颜SDK与美颜接口的开发实践
  • MySQL——数据库和表的基本操作(一)数据库基础知识
  • SCSS入门指南:基本语法与高效用法
  • xshell7和XFTP个人免费版官方下载免激活
  • 【Python数据分析】基于自回归积分滑动平均模型的疫情分析报告 附完整python代码
  • Python操作MySQL数据库的工具--sqlalchemy
  • 日用百货元宇宙 以科技创新培育产业新质生产力
  • tensorflow如何指定gpu运行还是cpu运行
  • Kotlin中 take、drop方法使用
  • 生命在于学习——Python人工智能原理(1.2)
  • go map
  • 【小技巧】KEIL C51 报错`Warning L6: XDATA Space Memory Overlap`
  • [前端] axios 请求成功了,为什么通过浏览器看不到返回数据
  • 极致优化之道-JVM字节码调优全揭秘
  • [原]深入对比数据科学工具箱:Python和R 非结构化数据的结构化
  • 【挥舞JS】JS实现继承,封装一个extends方法
  • canvas 五子棋游戏
  • Create React App 使用
  • input的行数自动增减
  • Java到底能干嘛?
  • markdown编辑器简评
  • node学习系列之简单文件上传
  • PAT A1120
  • ReactNative开发常用的三方模块
  • RxJS 实现摩斯密码(Morse) 【内附脑图】
  • UMLCHINA 首席专家潘加宇鼎力推荐
  • vue2.0开发聊天程序(四) 完整体验一次Vue开发(下)
  • 番外篇1:在Windows环境下安装JDK
  • 浮动相关
  • 构建工具 - 收藏集 - 掘金
  • 前端技术周刊 2019-02-11 Serverless
  • 前端性能优化——回流与重绘
  • 如何在GitHub上创建个人博客
  • 我是如何设计 Upload 上传组件的
  • 携程小程序初体验
  • 一些关于Rust在2019年的思考
  • 数据库巡检项
  • ​软考-高级-系统架构设计师教程(清华第2版)【第1章-绪论-思维导图】​
  • ​软考-高级-系统架构设计师教程(清华第2版)【第9章 软件可靠性基础知识(P320~344)-思维导图】​
  • #systemverilog# 之 event region 和 timeslot 仿真调度(十)高层次视角看仿真调度事件的发生
  • $(selector).each()和$.each()的区别
  • (1)虚拟机的安装与使用,linux系统安装
  • (Arcgis)Python编程批量将HDF5文件转换为TIFF格式并应用地理转换和投影信息
  • (附表设计)不是我吹!超级全面的权限系统设计方案面世了
  • (附源码)ssm高校实验室 毕业设计 800008
  • (黑马点评)二、短信登录功能实现
  • (三)Kafka离线安装 - ZooKeeper开机自启
  • (顺序)容器的好伴侣 --- 容器适配器
  • (详细文档!)javaswing图书管理系统+mysql数据库
  • (一)Java算法:二分查找
  • .CSS-hover 的解释
  • .NET Core 实现 Redis 批量查询指定格式的Key
  • .NET WPF 抖动动画
  • /bin/rm: 参数列表过长"的解决办法