使用最小花费爬楼梯 | 动态规划

2024-06-02 16:28

本文主要是介绍使用最小花费爬楼梯 | 动态规划,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.使用最小花费爬楼梯

题目连接:746. 使用最小花费爬楼梯
给你一个整数数组 cost ,其中 cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。一旦你支付此费用,即可选择向上爬一个或者两个台阶。

你可以选择从下标为 0 或下标为 1 的台阶开始爬楼梯。请你计算并返回达到楼梯顶部的最低花费。

2.题目解读在这里插入图片描述

例如上面的例子,从下标为0的地方开始爬楼梯,向上爬一个或者两个台阶,最后到达顶部,输出6。其实两个问题,就是我怎么知道从0下标还是1下标开始?我怎么知道是要爬一个还是两个台阶?

3.解决问题(解法一)

(1)、状态表示
上面的问题1,我怎么知道从0下标还是1下标开始?只需要定义dp[i]为到达 i 位置时的最⼩花费即可。 如:dp[3]根据以往的计算这个就是最小花费,至于从0还是1下标,那就要问,dp[0]和dp[1]的最小花费是多少。
(2)、状态转移⽅程
根据以往的推出的结果(dp[i]之前或之后),来推导dp[i]。这里根据题目推导状态转移方程,即可解决知道是要爬一个还是两个台阶(最优即:最小花费)。
在这里插入图片描述
(3)、初始化
dp[0] = dp[1] = 0本来就可以在0或1下标。
(4)、初始化顺序
这里根据题目要求,根据状态转移方程,从左往右,将dp填充。
(5)、返回值
返回dp[n]即为,返回结果。

4.参考代码(解法一)

C++版本:

class Solution {
public:int minCostClimbingStairs(vector<int>& cost) {int n = cost.size();vector<int> dp(n + 1);for(int i = 2;i <= n;i++){dp[i] = min(dp[i - 1] + cost[i - 1],dp[i - 2] + cost[i - 2]);}return dp[n];}
};

Java版本:

class Solution {public int minCostClimbingStairs(int[] cost) {int n = cost.length;int dp[] = new int[n + 1];for(int i = 2;i <= n;i++){dp[i] = Math.min(cost[i - 1] + dp[i - 1],cost[i - 2] + dp[i -2]);}return dp[n];}
}
5.解决问题(解法二)

(1)、状态表示
dp[i]表示到达楼梯顶部的最少花费。
(2)、状态转移⽅程
在这里插入图片描述

(3)、初始化
dp[n -1] = cost[n-1],dp[n-2] = cost[n-2]
(4)、初始化顺序
这里根据题目要求,根据状态转移方程,从右往左,将dp填充。
(5)、返回值
返回min(dp[0],dp[i])就是结果

6.参考代码(解法二)

C++版本:

class Solution {
public:int minCostClimbingStairs(vector<int>& cost) {int n = cost.size();vector<int> dp(n + 1);dp[n - 1] = cost[n - 1];dp[n - 2] = cost[n - 2];for(int i = n - 3;i >= 0;i--){dp[i] = min(cost[i] + dp[i + 1],cost[i] + dp[i + 2]);}return min(dp[0],dp[1]);}
};

这篇关于使用最小花费爬楼梯 | 动态规划的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1024483

相关文章

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

慢sql提前分析预警和动态sql替换-Mybatis-SQL

《慢sql提前分析预警和动态sql替换-Mybatis-SQL》为防止慢SQL问题而开发的MyBatis组件,该组件能够在开发、测试阶段自动分析SQL语句,并在出现慢SQL问题时通过Ducc配置实现动... 目录背景解决思路开源方案调研设计方案详细设计使用方法1、引入依赖jar包2、配置组件XML3、核心配

Git可视化管理工具(SourceTree)使用操作大全经典

《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设

Python使用Matplotlib绘制3D曲面图详解

《Python使用Matplotlib绘制3D曲面图详解》:本文主要介绍Python使用Matplotlib绘制3D曲面图,在Python中,使用Matplotlib库绘制3D曲面图可以通过mpl... 目录准备工作绘制简单的 3D 曲面图绘制 3D 曲面图添加线框和透明度控制图形视角Matplotlib

Pandas中统计汇总可视化函数plot()的使用

《Pandas中统计汇总可视化函数plot()的使用》Pandas提供了许多强大的数据处理和分析功能,其中plot()函数就是其可视化功能的一个重要组成部分,本文主要介绍了Pandas中统计汇总可视化... 目录一、plot()函数简介二、plot()函数的基本用法三、plot()函数的参数详解四、使用pl

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展