代码随想录算法训练营Day38|动态规划理论基础、2.斐波那契数、3.爬楼梯、4.使用最小花费爬楼梯

动态规划理论基础

代码随想录 (programmercarl.com)

动态规划(Dynamic Programming,简称DP)是一种算法设计技术,它通过将复杂问题分解为更小的子问题来解决优化问题。动态规划通常用于解决那些具有重叠子问题和最优子结构特性的问题。(可以理解为一种递推)

重叠子问题:

        在递归算法中,相同的子问题会被多次计算。动态规划通过存储这些子问题的解来避免计算。这个存储通常使用一个表格(数组)来实现,称为备忘录或DP表。

最优子结构:

        一个问题的最优解包含其子问题的最优解。这意味着可以通过组合子问题的最优解来构造原问题的最优解。

动态规划的通常步骤:

  1. 定义状态:确定DP数组的含义,即dp[i]通常代表什么意义,比如在斐波那契数列问题中,dp[i]代表第i个斐波那契数。
  2. 状态转移方法:确定状态之间如何转移,即如何从一个或多个已知状态的值计算出下一个状态的值,如斐波那契数中 F[i] = F[i-1] + F[i-2]。
  3. 初始化:确定DP数组的初始值,这些通常关乎问题的边界条件。如斐波那契数中F[0] = 0,F[1] = 1。
  4. 计算顺序:确定DP数组的计算顺序,通常需要按照逻辑顺序从小到大计算。如斐波那契数列需要一次从2开始向后计算得到想要的值。
  5. 返回结果:根据DP数组的最终值来确定原问题的解。如返回你需要的斐波那契数。

斐波那契数

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

递推顺序为 F(n) = F(n-1)+F(n-2)

F(0) = 0, F(1) = 1

class Solution {
public:int fib(int n) {// 如果 n 小于或等于 1,直接返回 n// 这是因为斐波那契数列的前两个数是定义好的:F(0) = 0, F(1) = 1if(n<=1) return n;// 创建一个动态数组 dp,大小为 n+1,用于存储斐波那契数列vector<int>dp(n+1);// 初始化 dp 数组的前两个数,即 F(0) 和 F(1)dp[0] = 0;dp[1] = 1;// 从 2 开始循环到 n,计算 dp 数组的其余值for(int i = 2; i <= n; i++){// 根据斐波那契数列的定义,每个数是前两个数的和dp[i] = dp[i-1]+ dp[i-2];}// 返回 dp 数组的最后一个值,即斐波那契数列的第 n 个数return dp[n];}
};

算法的时间复杂度为O(n),空间复杂度同样为O(n),需要维护一个斐波那契数数组。

爬楼梯

70. 爬楼梯 - 力扣(LeetCode)

斐波那契数的一个变体,开始没想到,想到之后只能感慨代码随想录的题目顺序还是很用心的。

假设爬到第i-1层有x种方案,爬到第i-2层有y种方案,那么爬到第i层有x+y种方案(第i-1层再向上爬一层达到i,第i-2层向上爬2层到达i层)。由此,就能看出这个问题是上述斐波那契数的变体。递推关系为dp[i] = dp[i-1] + dp[i-2],从前往后遍历,dp[0] = 0,dp[1] = 1,爬到1层只有一种方案,dp[2] =2,爬到2层有2种可能 1 1 和 2。具体代码如下,我考虑从3开始计算,最后返回dp[n]。

class Solution {
public:// 定义一个名为 climbStairs 的函数,用于计算爬到第 n 阶楼梯的方法数int climbStairs(int n) {// 如果 n 小于或等于 2,直接返回 n// 这是因为当楼梯阶数不超过 2 时,方法数与楼梯阶数相同if(n<=2) return n;// 创建一个动态数组 dp,大小为 n+1,用于存储到达每一阶楼梯的方法数vector<int>dp(n+1);// 初始化 dp 数组的前三个数,即到达第 0、1、2 阶的方法数// 到达第 0 阶的方法数为 0,因为还没有开始爬,这里也可以认为是1,能减少一点代码量    // 这样dp[2]不用赋值dp[0] = 0;// 到达第 1 阶的方法数为 1,只能爬 1 阶dp[1] = 1;// 到达第 2 阶的方法数为 2,可以一次爬 2 阶或者分两次各爬 1 阶dp[2] = 2;// 从 3 开始循环到 n,计算 dp 数组的其余值for(int i = 3; i <= n; i++){// 根据问题的性质,到达第 i 阶的方法数是到达第 i-1 阶和第 i-2 阶的方法数之和// 这是因为每次你可以选择爬 1 阶或 2 阶,所以到达第 i 阶的方法可以从第 i-1 阶爬上来,或者从第 i-2 阶爬上来dp[i] = dp[i-1] + dp[i-2];}// 返回 dp 数组的最后一个值,即到达第 n 阶的方法数return dp[n];}
};

算法的时间复杂度为O(n),空间复杂度同样为O(n),需要维护一个斐波那契数数组。

使用最小花费爬楼梯

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

这里同样是上述问题的变种,但需要考虑的是,这里不是找方案,而是计算损失,所以动态规划数组dp[i]代表的是到达n前的最小花费,到达第i层需要分别计算到达第i-1层和到达第i-2层的损失,然后选择较小的值作为dp[i]的值。由于在到达最终的n层前,每次到达一个i都需要起跳,所以需要添加损失,dp[i]为min(dp[i-1]+cost[i],dp[i-2]+cost[i]),而最后抵达n时,不再需要起跳,只需要考虑dp[n-1]和dp[n-2]的较小值,就是爬楼梯所需的最小花费。

class Solution {
public:int minCostClimbingStairs(vector<int>& cost) {// 获取楼梯的阶数,即成本数组的大小int n = cost.size();// 创建一个动态数组 dp,大小为 n,用于存储到达每一阶楼梯的最小成本vector<int>dp(n);// 初始化 dp 数组的前两个数,即到达第 0、1 阶的最小成本// 到达第 0 阶的成本就是 cost[0]dp[0] = cost[0];// 到达第 1 阶的成本就是 cost[1]dp[1] = cost[1];// 从第 2 阶开始循环到第 n-1 阶,计算 dp 数组的其余值for(int i = 2; i < n; i++){// 到达第 i 阶的最小成本是到达第 i-1 阶和第 i-2 阶的最小成本加上当前阶梯的成本中的较小值// 这是因为每次你可以选择从第 i-1 阶爬上来或者从第 i-2 阶爬上来dp[i] = min(dp[i-1] + cost[i], dp[i-2] + cost[i]);}// 最后,到达楼顶的最小成本是到达倒数第一阶和倒数第二阶的最小成本中的较小值// 因为你可以从倒数第一阶直接到达楼顶,也可以从倒数第二阶直接到达楼顶return min(dp[n-2], dp[n-1]);}
};

算法的时间复杂度为O(n),遍历cost数组,并计算得到dp数组,空间复杂度同样为O(n),需要维护一个dp数组。

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

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

相关文章

安卓交叉编译——ndk

下载NDK The Native Development Kit (NDK)特指Android NDK&#xff0c;是为了服务安卓开发的。通过ndk&#xff0c;安卓也可以使用java之外的native code,如c&#xff0c;c&#xff0c;甚至c和c对应的library也可以得以复用&#xff0c;这就大大减少了重复开发。 The Native …

【Numpy】一文向您详细介绍 np.floor()

【Numpy】一文向您详细介绍 np.floor() 下滑即可查看博客内容 &#x1f308; 欢迎莅临我的个人主页 &#x1f448;这里是我静心耕耘深度学习领域、真诚分享知识与智慧的小天地&#xff01;&#x1f387; &#x1f393; 博主简介&#xff1a;985高校的普通本硕&#xff0c;…

基于Python+Django+MySQL+HTML的创新创业平台

DjangoMySQLHTML 基于PythonDjangoMySQLHTML的创新创业平台 用户管理 系统监控 角色管理 资源管理 参数设置 角色管理 简介 学生创新创业平台是一个功能丰富的在线教育或协作系统&#xff0c;支持中文语言环境。它提供用户管理、系统监控、多角色权限控制、资源管理、参…

Linux目录的作用和常用指令

目录结构及其详细作用 / (根目录) Linux文件系统的起点&#xff0c;所有文件和目录都在其下。 /bin 存放系统启动和运行时所需的基本命令&#xff0c;如 ls, cp, mv, rm&#xff0c;这些命令在单用户模式下或系统崩溃时仍然可用。 /boot 包含启动引导加载器的文件和Linux内核…

mac下Xcode在iphone真机上测试运行iOS软件

最近一个需求需要在iPhone真机上测试一个视频直播的项目。 需要解决如何将项目 app 安装到真机上 在进行真机调试。 安装Xcode 直接在App Store上搜索Xcode安装即可。 关键是要安装Simulator。项目需要安装iOS17.5但是由于安装包太大&#xff0c;并且网络不稳定的原因。在Xco…

Databricks超10亿美元收购Tabular;Zilliz 推出 Milvus Lite ; 腾讯云支持Redis 7.0

重要更新 1. Databricks超10亿美元收购Tabular&#xff0c;Databricks将增强 Delta Lake 和 Iceberg 社区合作&#xff0c;以实现 Lakehouse 底层格式的开放与兼容([1] [2])。 2. Zilliz 推出 Milvus Lite 轻量级向量数据库&#xff0c;支持本地运行&#xff1b;Milvus Lite 复…

C++入门 vector介绍及使用

目录 vector的介绍及使用 vector常用接口的介绍及使用 vector的定义 vector iterator 的使用 vector 空间增长问题 vector 增删查改 push_back/pop_back insert & erase & find operator[ ]的遍历 vector的介绍及使用 vector的文档介绍 vector是表示可变大…

Vue使用vue-esign实现在线签名

Vue在线签名 一、目的二、样式三、代码1、依赖2、代码2.1 在线签名组件2.2父组件 一、目的 又来了一个问题&#xff0c;直接让我在线签名&#xff08;还不能存储base64&#xff09;&#xff0c;并且还得上传&#xff0c;我直接***违禁词。 二、样式 初始样式 点击前往组件&am…

C++中如何选择整型类型存储数据?

C中如何选择整型类型存储数据&#xff1f; C提供了大量的整型&#xff0c;应使用哪种类型呢?通常&#xff0c;int被设置为对目标计算机而言最为“自然”的长度。自然长度(natural size)指的是计算机处理起来效率最高的长度。如果没有非常有说服力的理由来选择其他类型&#x…

金蝶云星空程序员开发快速入门

文章目录 一 前言1.1 学习步骤1.2 学习需知 二、学习金蝶*云星空的步骤2.1 下载金蝶*云星空安装到本地2.2 查看官网的学习资料2.3 如何使用C#进行插件开发2.4 sqlserver的表设计以及存储过程2.5 如何使用python进行插件的开发2.6 第三方程序如何调用金蝶*云星空的数据 三 后记 …

1089 狼人杀-简单版

solution 有两个狼人&#xff0c;其中一个狼人说谎&#xff0c;找到符合该条件的方案。若有多种则输出序号最小的方案&#xff0c;若无方案则输出No Solution。 枚举所以狼人的可能性&#xff0c;找到符合的方案输出并结束。 #include<iostream> using namespace std; …

Flyway 数据库迁移工具详解:安装、配置与使用教程

Flyway 数据库迁移工具详解&#xff1a;安装、配置与使用教程 Flyway 是一个开源的数据库迁移工具&#xff0c;用于管理和自动化数据库的版本控制。它可以与各种关系型数据库配合使用&#xff0c;帮助开发团队在应用程序开发生命周期中轻松处理数据库模式的变更。以下是 Flywa…

【CSS】text-decoration-skip是做什么用的,怎么使用

CSS的text-decoration-skip属性用于定义元素哪些部分的内容需要被文本修饰&#xff08;如下划线、上划线、删除线等&#xff09;所跳过。这可以控制所有该元素或该元素的祖先所绘制的文本修饰线。 text-decoration-skip的工作原理&#xff1a; 以text-decoration-skip: ink;为…

CSRF攻击

改账号和密码 里面有改的账号和密码 我改这个代码的123为456&#xff0c;然后在新的浏览器去执行&#xff0c;然后密码就又被改了 假如黑客知道修改密码的url&#xff0c;那么就危险了 但是也不是随便改 是有前提的&#xff0c;前提是&#xff1a; 1、已经登录了要改密码的…

计算机网络:网络层 - IPv6

计算机网络&#xff1a;网络层 - IPv6 IPv6 数据报IPv6 地址冒号十六进制记法地址分类 IPv4 到 IPv6 过渡双栈协议隧道技术 IPv6 是互联网协议的最新版本&#xff0c;它被设计用来取代现有的 IPv4 协议。这是因为 IPv4 存在一些根本性的限制&#xff0c;而 IPv6 则可以解决这些…

【three.js案例一】智慧星球

直接附上源码: import * as THREE from three; import { OrbitControls } from three/addons/controls/OrbitControls.js;//场景 const scene = new THREE.Scene();const geometry = new THREE.SphereGeometry(50,32,16);console.log(.postion,geometry.attributes.position)…

【吊打面试官系列-Mysql面试题】实践中如何优化 MySQL?

大家好&#xff0c;我是锋哥。今天分享关于 【实践中如何优化 MySQL&#xff1f;】面试题&#xff0c;希望对大家有帮助&#xff1b; 实践中如何优化 MySQL&#xff1f; 最好是按照以下顺序优化&#xff1a; 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 1、SQL 语…

python内置函数+lambda函数

文章目录 前言1 类型转换int():将值转换为整数(十进制转换)float():将值转换为浮点数str():将值转换为字符串bool(): 将值转换为布尔值round()函数:四舍五入complex()---用来生成复数,当然复数也可手打,该函数与,int(),float()相比并没有变成复数类型的作用2 进制…

【Linux】基础IO——理解文件系统

1.理解文件系统 1.1.ls与stat 磁盘文件由两部分构成&#xff0c;分别是文件内容和文件属性。 文件内容就是文件当中存储的数据&#xff0c;文件属性就是文件的一些基本信息&#xff0c; 例如文件名、文件大小以及文件创建时间等信息都是文件属性&#xff0c;文件属性又被称…

探索高效存储与快速查找: 深入了解B树数据结构

探索高效存储与快速查找: 深入了解B树数据结构 一、什么是B树二、B树的实现2.1 节点的定义2.2 插入关键字2.3 删除关键字2.4 查找关键字2.5 遍历B树 一、什么是B树 B树&#xff0c;也称为B-tree&#xff0c;是一种多路平衡查找树。它被广泛用于文件系统和数据库之中&#xff0c…