C++笔试练习笔记【5】:最小花费爬楼梯(有题目链接) 初识动态规划
文章目录
- 题目
- 思路
- 代码
- 动态规划简介
- **一、什么是动态规划**
- **二、动态规划的应用场景**
- **三、动态规划的基本步骤**
- **四、动态规划的优缺点**
题目
题目链接:https://www.nowcoder.com/practice/9b969a3ec20149e3b870b256ad40844e?tpld=230&tpld=39751&ru=/exam/oj

思路
有几个细节要明确

- const[i]是在离开时花费的体力所以在离开时才会加
- 根据例子我们能知道数组给了i个数我们下标到达i才算到顶,如图如果我们必须到达cost[i+1]才算登顶
动态规划:
- 状态表示:
dp[i]:到达i位置所用最小花费 - 状态转移方程

因为一次只能向上一个台阶或者两个台阶所以只有i-1,i-2两种可能。
dp[i]=min(dp[i-1]+cost[i-1],dp[i-2]+cost[i-2]);
代码
#include <iostream>
using namespace std;#define N 100010int main() {int cost[N]={0};int dp[N]={0};int n;cin >> n;for(int i=0;i<n;i++)cin >> cost[i];for(int i=2;i<=n;i++)dp[i]=min(dp[i-1]+cost[i-1],dp[i-2]+cost[i-2]);cout << dp[n] << endl;return 0;
}
动态规划简介
一、什么是动态规划
动态规划(Dynamic Programming)是一种在解决多阶段决策问题时常用的算法思想。它通过将复杂问题分解成一系列相互关联的子问题,并按照一定的顺序求解这些子问题,从而避免了重复计算,提高了算法的效率。上面的题的思想就是动态规划。
动态规划的核心思想是“最优子结构”和“重叠子问题”。最优子结构意味着一个问题的最优解包含了其子问题的最优解。重叠子问题则是指在求解过程中,相同的子问题会被多次计算。
二、动态规划的应用场景
动态规划在许多领域都有广泛的应用,例如:
- 求解最短路问题,如在图中找到从一个节点到另一个节点的最短路径。
- 例如,在一个城市交通网络中,寻找从起点到终点的最短行驶路线。
- 资源分配问题,如何合理分配有限的资源以达到最优效果。
- 比如在项目管理中,合理分配人力和时间资源,以使项目能够在最短时间内完成。
- 背包问题,给定一组物品和一个背包容量,选择哪些物品放入背包能使价值最大化。
三、动态规划的基本步骤
- 定义状态表示:明确问题中的状态变量,这些变量通常用来描述子问题的解。
- 建立状态转移方程:找出不同状态之间的关系,确定如何从一个状态转移到另一个状态。
- 初始化边界条件:确定初始状态的值。
- 按照合适的顺序计算状态值:通常是从边界条件开始,逐步计算其他状态的值。
四、动态规划的优缺点
优点:
- 能够有效地降低算法的时间复杂度,避免重复计算。
- 对于具有最优子结构和重叠子问题的问题,能够得到最优解。
缺点:
- 空间复杂度可能较高,需要存储状态值。
- 状态定义和转移方程的推导可能比较困难,需要对问题有深入的理解。
总之,动态规划是一种强大的算法思想,掌握它对于解决许多复杂的优化问题具有重要意义。但在实际应用中,需要根据具体问题的特点来选择是否使用动态规划以及如何设计有效的算法。
相关文章:
C++笔试练习笔记【5】:最小花费爬楼梯(有题目链接) 初识动态规划
文章目录 题目思路代码 动态规划简介**一、什么是动态规划****二、动态规划的应用场景****三、动态规划的基本步骤****四、动态规划的优缺点** 题目 题目链接:https://www.nowcoder.com/practice/9b969a3ec20149e3b870b256ad40844e?tpld230&tpld39751&ru/…...
数据结构----------贪心算法
什么是贪心算法? 贪心算法(Greedy Algorithm)是一种在问题求解过程中,每一步都采取当前状态下最优(即最有利)的选择,从而希望导致最终的全局最优解的算法策略。 贪心算法的核心思想是做选择时&…...
C++初学(11)
不知不觉就第11篇了QWQ 11.1、指针和自由存储空间 之前提到了计算机程序在存储数据时必须跟踪的3个基本属性: (1)信息存储在何处; (2)存储的值为多少; (3)存储的信息…...
Vba选择cad中不同类型图元(Select Case True语句和like用法)
Select Case True 是一个常见的VBA编程技巧,用于在多个条件之间进行选择。具体来说,Select Case True 语句的每个 Case 语句都包含一个布尔表达式,这些表达式会逐个与 True 进行比较。当其中一个表达式的结果为 True 时,对应的代码…...
Kafka基本讲解
Kafka基本讲解 一:Kafka介绍 Kafka是分布式消息队列,主要设计用于高吞吐量的数据处理和消息传输,适用于日志处理、实时数据管道等场景。Kafka作为实时数仓架构的核心组件,用于收集、缓存和分发实时数据流,支持复杂的…...
thinkphp6项目初始化配置方案二次修正版本
数据返回统一格式 app/BaseController.php新增文件内容在末尾,并在构造函数中实例化数据模型类 // 成功统一返回格式 function Result($data, $msg , $code 200, $httpCode 200): \think\response\Json {$res [code > $code,msg > $msg,data > $data];return j…...
XXE靶机教学
arp-scan -l主机发现 arp-scan -l 端口扫描 nmap -p- 192.168.48.139 服务探测 nmap -p80,5355 -sT -sC -sV 192.168.48.139 目录扫描 dirsearch -u http://192.168.48.139 访问robots.txt 发现两个可访问路径 burp抓包 测试是否存在xxe漏洞 <?xml version "1.…...
干货 | 2024步入数字化转型深水区,云原生业务稳定性如何保障(免费下载)
云原生业务的稳定性保障是一个涉及多个层面的复杂任务,以下是一些关键措施和策略,以确保云原生业务的高效稳定运行: 一、平台安全性评估与加固 云原生平台安全评估:对云原生平台(如Kubernetes、Docker等)…...
for(char c:s),std::vector<int> numbers 和std::int numbers[],.size()和.sizeof()区别
在C中当需要对某个容器或数组进行遍历时我们可以使用以下语句,c将会被赋值为s中的元素 for(char c:s)://s可以是任何满足条件的容器或数组for(int c:s):for(double c:s):for(float c:s):在C中我们来区分std::vector numbers {1, 2, 3, 4, 5};和std::int numbers[] …...
桌面云备份可以删除吗?安不安全
桌面云备份可以删除吗?答案是可以的。如果用户不需要这些备份或者想要释放存储空间,桌面云备份是可以进行删除的,并且删除桌面云备份是一个相对安全的过程,但需要注意以下几点来确保操作的安全性和数据的完整性。 一、桌面云备份…...
【爬虫实战】利用代理爬取电商数据
文章目录 前言工具介绍实战获取网站数据编写代码数据展示 推荐总结 前言 当今电商平台正经历着快速的转型与升级。随着技术的进步和用户需求的多样化,电商不仅从简单的在线购物演变为综合性的购物生态系统,还融合了人工智能、大数据和云计算等先进技术。…...
python如何统计列表中元素出现的次数
在 Python 中,可以使用多种方法来统计列表中元素出现的次数。以下是一些常用的方法: 方法 1: 使用 count() 方法 list 对象有一个内置的 count() 方法,可以直接统计某个元素在列表中出现的次数。 my_list [1, 2, 3, 2, 1, 4, 2] count_of…...
【算法】山脉数组的峰顶索引
难度:中等 题目描述: 给定一个长度为 n 的整数 山脉 数组 arr ,其中的值递增到一个 峰值元素 然后递减。 返回峰值元素的下标。 你必须设计并实现时间复杂度为 O(log(n)) 的解决方案。 示例 1: 输入:arr [0,1,0]…...
牛客 JZ31.栈的压入,弹出序列 C++写法
牛客 JZ31.栈的压入,弹出序列 C写法 思路🤔: 创建一个栈,push压入序列,然后用栈顶跟弹出序列比,如果一样就出栈并且继续比较,不一样就再次push入栈,直到压入序列走完,如果…...
PageHelper在Mybatis的一对多表关联时total数错误
最近在学习PageHelper遇到一个bug记录一下: 在Mybatis的一对多表中,PageHelper获取的total是所有的记录数,而不是我想要的第一次sql的记录数。 解决方案1: 不要在mapper层获取一对多关联,在service层先获取一&#…...
(20240806)硫氧镁 / 碱式硫酸镁-混凝土
一、目录 一篇博士论文,5篇硕士论文,南京航空航天大学双一流211,60。余红发团队 具体涉及到 (1) 碱式硫酸镁水泥的混凝土应用 、(一篇博士论文) 有微观分析 (2)混…...
string类的模拟实现(C++)
一、前言 想要模拟实现一个库中的类,那就要首先要熟悉如何使用这个类。建议通过下面博客,完成对Cstring类的学习。 C的string类-CSDN博客 二、模拟实现 我们将从string的成员函数即成员变量入手,模拟实现string类。 成员变量 string类的…...
C++_sizeof的相关知识点
1.指针的大小永远是固定的,取决于处理器位数,32位就是 4 字节,64位就是 8 字节 2.数组作为函数参数时会退化为指针,大小要按指针的计算 int func(char array[]) {printf("sizeof%d\n", sizeof(array));printf("s…...
Istio Proxy的Envoy代理架构中,Upstream提供的功能是:
Istio Proxy的Envoy代理架构中,Upstream提供的功能是: A. 接收来自Envoy连接和请求的主机,并返回响应 B. 连接的一组逻辑相同的上游主机 C. 将下游主机连接到Envoy的主机,用来发送请求并接受响应 选择A Istio Proxy的Envoy代理架…...
LeetCode 热题 HOT 100 (015/100)【宇宙最简单版】
【栈】No. 0155 最小栈【中等】👉力扣对应题目指路 希望对你有帮助呀!!💜💜 如有更好理解的思路,欢迎大家留言补充 ~ 一起加油叭 💦 欢迎关注、订阅专栏 【力扣详解】谢谢你的支持! …...
农村与中小城市的数字化,藏着被忽略的技术蓝海
被忽视的数字新大陆当一线城市的数字化转型趋于饱和,农村与中小城市正悄然成为技术落地的"价值洼地"。这片蓝海蕴藏着庞大的场景创新空间,却因基础设施薄弱、用户群体特殊、生态体系未成型等痛点被长期忽视。对软件测试从业者而言,…...
AIDE 实战指南:从安装到入侵检测的完整流程
1. AIDE入门:为什么你需要文件完整性监控 第一次听说AIDE这个工具时,我正经历着职业生涯中最尴尬的安全事故。某天凌晨,服务器突然开始疯狂发送垃圾邮件,排查了半天才发现是某个关键系统文件被悄悄篡改了。这件事让我意识到&#…...
避坑指南:ESP32用摇杆控制舵机,为什么你的舵机会抖?
ESP32摇杆控制舵机抖动问题全解析:从硬件设计到代码优化的完整避坑指南 当你兴奋地组装好ESP32、摇杆和舵机,准备实现酷炫的机械控制时,却发现舵机像得了帕金森一样不停抖动——这种挫败感我太熟悉了。经过数十个项目的实战积累,我…...
开源中国全栈式AI教育解决方案:从算力调度到人才培养的闭环实践
在北京教育装备展示会的聚光灯下,开源中国以其教育业务的战略升级成为行业焦点。这家以开发者社区起家的科技企业,正通过构建覆盖K12至高等教育的全学段AI基础设施,重塑教育数字化转型的底层逻辑。其推出的国产化算力异构调度平台、"模力…...
Claude Code 行为指南
Claude Code 行为指南 背景与问题 Andrej Karpathy(前 OpenAI 创始成员、前 Tesla AI 总监)在社交媒体上分享了他对 LLM 编码行为的观察:“模型会替你做出错误的假设并直接执行,而不去验证。它们不管理自己的困惑,不寻…...
6G这事,我研究了3个月,说点不太好听的实话
🧠《6G这事,我研究了3个月,说点不太好听的实话》🪓一、先泼冷水:大部分人根本不需要6G这话可能不太讨喜,但先说结论: 👉 90%的人,用不上6G你现在用手机: 刷视…...
AI时代的算法思维:大经典排序学习拐
引言 在现代软件开发中,性能始终是衡量应用质量的重要指标之一。无论是企业级应用、云服务还是桌面程序,性能优化都能显著提升用户体验、降低基础设施成本并增强系统的可扩展性。对于使用 C# 开发的应用程序而言,性能优化涉及多个层面&#x…...
aibiye的AI改写工具通过五项措施,帮助30%重复率论文快速合规。采用语义扩展、数据强化等技术,精准降低相似度,提升稿件质量。
嘿,大家好!我是AI菌。今天咱们来聊聊一个让无数学生头疼的问题:论文重复率飙到30%以上怎么办?别慌,我这就分享5个实用降重技巧,帮你一次搞定,轻松压到合格线以下。这些方法都是我亲身试验过的&a…...
面对30%的论文重复率,aibiye的AI工具提出五条降重策略。自动优化引用格式、调整语序结构,使文本更符合原创标准,减少人工干预。
论文重复率超过30%时,可以通过多种方法有效降低重复率。调整句子结构、替换同义词、转换表达方式是常见的人工降重手段,能够在不改变原意的前提下显著减少重复内容。采用图表展示数据、增加案例分析等技巧,既能丰富论文形式又能降低重复率。合…...
3分钟零门槛安装:Axure RP中文语言包全面解析
3分钟零门槛安装:Axure RP中文语言包全面解析 【免费下载链接】axure-cn Chinese language file for Axure RP. Axure RP 简体中文语言包。支持 Axure 11、10、9。不定期更新。 项目地址: https://gitcode.com/gh_mirrors/ax/axure-cn 还在为Axure RP的英文界…...
