代码随想录算法训练营第33天—动态规划01 | ● 理论基础 ● 509. 斐波那契数 ● *70. 爬楼梯 ● *746. 使用最小花费爬楼梯

动态规划理论基础

https://programmercarl.com/%E5%8A%A8%E6%80%81%E8%A7%84%E5%88%92%E7%90%86%E8%AE%BA%E5%9F%BA%E7%A1%80.html
视频:https://www.bilibili.com/video/BV13Q4y197Wg

  • 主要题型
    • 动规基础题
      • 斐波那契数列(爬楼梯)
    • 背包问题
    • 打家劫舍
    • 股票问题
    • 子序列问题
  • 解题五步走
    • dp数组及下标的含义
    • 递推公式
    • dp数组的初始化
    • 遍历顺序
    • 打印dp数组(用于debug)

509. 斐波那契数

https://programmercarl.com/0509.%E6%96%90%E6%B3%A2%E9%82%A3%E5%A5%91%E6%95%B0.html
视频:https://www.bilibili.com/video/BV1f5411K7mo

  • 考点
    • 动规
  • 我的思路
    • 不自觉地就用动规五部曲写出来了
  • 视频讲解关键点总结
    • 动规五部曲
    • 确定dp数组及其下标含义
      • dp为斐波那契数列,dp[i]为第i个斐波那契数
    • 递推公式
      • dp[i] = dp[i - 1] + dp[i + 1]
    • 初始化
      • dp[0] = 0
      • dp[1] = 1
    • 遍历顺序
      • 前到后
    • 打印
      • 本题无须debug
  • 我的思路的问题
  • 代码书写问题
  • 可执行代码
class Solution:def fib(self, n: int) -> int:fib_list = [0, 1]if n == 0:return 0if n == 1:return 1for i in range(2, n + 1):fib_list.append(fib_list[i - 2] + fib_list[i - 1])return fib_list[n]

*70. 爬楼梯

https://programmercarl.com/0070.%E7%88%AC%E6%A5%BC%E6%A2%AF.html
视频:https://www.bilibili.com/video/BV17h411h7UH

  • 考点
    • 动规
    • 爬楼梯(斐波那契数列)
  • 我的思路
    • 无思路
  • 视频讲解关键点总结
    • 对于第n个台阶,有两种方式能走到它,第一种是从第n-2个台阶上迈两阶上来,第二种是从第n-1个台阶上迈一阶上来,因此,上到第n个台阶的方法总数等于上到第n-2个台阶和第n-1个台阶的方法数量和,也就是斐波那契数列
    • 动规五部曲
      • dp数组下标i的含义是上到第i-1个台阶有多少种方法
      • 递归公式和上一题相同
      • 初始化和上一题相同
      • 遍历顺序和上一题一样
      • 无需打印dp数组
  • 我的思路的问题
    • 无思路
  • 代码书写问题
  • 可执行代码
class Solution:def climbStairs(self, n: int) -> int:result = [1, 2]for i in range(2, n):result.append(result[i - 1] + result[i - 2])return result[n - 1]

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

https://programmercarl.com/0746.%E4%BD%BF%E7%94%A8%E6%9C%80%E5%B0%8F%E8%8A%B1%E8%B4%B9%E7%88%AC%E6%A5%BC%E6%A2%AF.html
视频讲解:https://www.bilibili.com/video/BV16G411c7yZ

  • 考点
    • 动规
    • 爬楼梯(斐波那契数列)
  • 我的思路
    • 思路有偏差,想着从后向前遍历依次将最小值相加,但实际上这样没有递推,得不到最优解
  • 视频讲解关键点总结
    • 有两点需要明确:1,站在台阶上不花钱,只有走上去才花钱,因此初始化时,第0和1个台阶的dp数均为0;2,最后要迈过最后一个台阶,也就是如果20个台阶,要走到第21个“台阶”才完成任务
    • 动规五部曲
      • dp数组下标i代表爬过第i个楼梯的最小花费
      • 递推公式为当前dp值等于第i-1个台阶最小花费+其自身花费和第i-2个台阶最小花费+其自身花费中的较小者
      • 初始化,dp的第0个和第1个位置赋值为0
      • 从前向后遍历
      • 无需打印
  • 我的思路的问题
    • 思路错误
  • 代码书写问题
  • 可执行代码
class Solution:def minCostClimbingStairs(self, cost: List[int]) -> int:dp = [0, 0]for i in range(2, len(cost) + 1):dp.append(min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2]))return dp[-1]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/727524.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java中super关键字作用及解析

在 Java 中,super关键字主要有以下作用: 在子类构造方法中调用父类的构造方法:使用super关键字可以在子类的构造方法中显式调用父类的构造方法,以便继承父类的属性和行为。语法如下:这样可以确保父类的构造方法被正确…

回收站选址(CCF 201912-2)解题思路

分析 把x,y坐标拼接成一个字符串(x,y)作为Set的key,保存到Set中,遍历Set,取出坐标,然后判断上下左右四个点是否在Set中,如果在,进而判断,四个角是否在Set中,…

【操作系统学习笔记】文件管理1.6

【操作系统学习笔记】文件管理1.6 参考书籍: 王道考研 视频地址: Bilibili 文件存储空间管理 存储空间的划分与初始化 安装 Windows 操作系统的时候,一个必经步骤是磁盘分区。每个区分为目录区(存放文件目录信息 FCB、用于磁盘存储空间管理的信息&am…

算法题 — 三个数的最大乘机

三个数的最大乘机 整型数组 nums,在数组中找出由三个数字组成的最大乘机,并输出这个乘积。(乘积不会越界) 重点考察:线性扫描 排序法: public static void main(String[] args) {System.out.println(so…

万字详解,Java实现低配版线程池

文章目录 1.什么是线程池2.线程池的优势3.原理4.代码编写4.1 阻塞队列4.2 ThreadPool线程池4.3 Worker工作线程4.4 代码测试 5. 拒绝策略5.1 抽象Reject接口5.2 BlockingQueue新增tryPut方法5.3 修改ThreadPool的execute方法5.4 ThreadPool线程池构造函数修改5.5 拒绝策略实现1…

YoloV8改进策略:Block改进|自研Block,涨点超猛

参考模型 参考的Block,如下图: 我对Block做了修改,修改后的结构图如下: 代码详解 from timm.models.layers import DropPathfrom torch import Tensor def channel_shuffle(x: Tensor, groups: int

1. C++ 编译期多态与运行期多态

C 编译期多态与运行期多态 今日的C不再是个单纯的“带类的C”语言,它已经发展成为一个多种次语言所组成的语言集合,其中泛型编程与基于它的STL是C发展中最为出彩的那部分。在面向对象C编程中,多态是OO三大特性之一,这种多态称为运…

Kubernetes-3

Kubernetes学习第3天 Kubernetes-31、查看实时的cpu和内存消耗1.1、kubectl top node 2、卷的使用2.1、什么是卷?1. 解决数据持久性问题2. Kubernetes 中的卷抽象概念3. 共享数据示例4. Kubernetes 中的卷使用5. 不同类型的卷6. 灵活、可靠的数据管理 2.2、联想到do…

effective c++ 笔记 条款32-40

条款32:确定你的 public 继承塑模出 is-a 关系 public inheritance(公开继承)意味 “is-a”(是一种)的关系。子是父,父不是子,父具有一般性,子具有特殊性“public继承”意味is-a。适…

融资项目——通过OpenFeign在分布式微服务框架中实现微服务的远程调用

1.OpenFeign配置 首先&#xff0c;在需要调用其他的微服务的微服务中引入相关依赖。&#xff08;大多数项目中各微服务需要互相调用&#xff0c;可以直接在每个微服务中引入依赖&#xff09; <!--服务调用--><dependency><groupId>org.springframework.clou…

【Memory协议栈】NVRAM Manager 模块介绍

目录​​​​​​​ 前言 正文 1.功能简介 2.关键概念 3.功能详解 3.1 内存硬件抽象层Ea/Fee的寻址方案 3.2 基本存储对象Basic storage objects 3.2.1 NV Block 3.2.2 RAM Block 3.2.3 ROM Block 3.2.4 Administrative block 3.2.5 NV Block Header 3.3块管理类型…

JavaScript监听按键,禁止F12,禁止右键,禁止保存网页【Ctrl+s】等操作

禁止右键 document.oncontextmenu new Function("event.returnValuefalse;") //禁用右键禁止按键 其他键码&#xff1a;键码对照表 // 监听按键 document.onkeydown function () {// f12if (window.event && window.event.keyCode 123) {alert("F1…

云手机实现全方位的海外舆情监测

近年来&#xff0c;随着各大品牌在海外市场的崛起&#xff0c;海外舆情监测变得尤为重要。企业在拓展国际业务的同时&#xff0c;面临着海外市场的信息难获取、竞争激烈等问题。为解决这一难题&#xff0c;Ogcloud推出的云手机应运而生&#xff0c;为企业提供全方位的海外舆情监…

【软件测试】如何申请专利?

一、专利类型 在软件测试领域&#xff0c;可以申请发明专利、实用新型专利和外观设计专利。其中&#xff0c;发明专利是最常见的专利类型&#xff0c;它保护的是软件测试方法、系统和装置等技术方案。 二、申请专利的条件 申请专利需要满足新颖性、创造性和实用性三个条件。…

linux系统的运维有哪些工作,需要做好哪方面的知识储备?需要学些哪方面的技术?

Linux系统维护是一项复杂且重要的任务&#xff0c;涉及到多个方面的工作和知识储备。以下是一些主要的工作内容和所需的知识储备&#xff1a; 一、Linux系统维护的主要工作 系统安装与配置&#xff1a;包括选择合适的Linux发行版&#xff0c;通过光盘、USB或网络进行安装&…

PEIS源码 健康体检中心源码 C/S

目录 一、系统概述 二、系统开发环境 三、系统功能 检前管理 检中管理 检后管理 设备对接-PACS 设备对接-彩超 LIS-结果录入、审核、外送结果自动导入 一、系统概述 体检系统&#xff0c;是专为体检中心/医院体检科等体检机构&#xff0c;专门开发的全流程管理系…

HTML5:七天学会基础动画网页9

在进行接下来的了解之前我们先来看一下3d的xyz轴&#xff0c;下面图中中间的平面就相当于电脑屏幕&#xff0c;z轴上是一个近大远小的效果。 3d转换属性 transform 2D或3D转换 transform-origin 改变旋转点位置 transform-style 嵌套元素在3D空间如何显 …

JumpServer 简介安装

目录 1、概念介绍 JumpServer 概述 JumpServer 功能 JumpServer 组件 JumpServer 架构 2、前置安装 环境要求 安装 ELRepo 库 更新内核 设置 grub2 安装 Python 配置 Python 虚拟环境 3、安装 Jumpserver Core 组件 下载安装 替换客户端组件 安装 Python 依赖库…

十六、正则查找网址

描述 GG Bond最近正在研究网址&#xff0c;他发现好像很多网址的开头都是https://www&#xff0c;他想知道任意一个网址都是这样开头吗。于是牛牛向你输入一个网址&#xff08;字符串形式&#xff09;&#xff0c;你能使用正则函数re.match在起始位置帮他匹配一下有多少位是相…

【Web】浅浅地聊SnakeYaml反序列化两条常见利用链

目录 关于Yaml 关于SnakeYaml SnakeYaml反序列化利用 JdbcRowSetImpl链 ScriptEngineManager链 复现 基本原理 继续深入 关于Yaml 学过SpringBoot开发的师傅都知道&#xff0c;YAML和 Properties 文件都是常见的配置文件格式&#xff0c;用于存储键值对数据。 这里举…