【学会动态规划】最佳买卖股票时机含冷冻期(15)
目录
动态规划怎么学?
1. 题目解析
2. 算法原理
1. 状态表示
2. 状态转移方程
3. 初始化
4. 填表顺序
5. 返回值
3. 代码编写
写在最后:
动态规划怎么学?
学习一个算法没有捷径,更何况是学习动态规划,
跟我一起刷动态规划算法题,一起学会动态规划!
1. 题目解析
题目链接:309. 最佳买卖股票时机含冷冻期 - 力扣(Leetcode)

这道题很好理解,其实就是买股票的时候多了一个冷冻期。
2. 算法原理
1. 状态表示
因为他有三种情况,所以我们也有三种状态表示:
dp[ i ][ 0 ] 表示第 i 天是 “买入” 状态,此时的最大利润。
dp[ i ][ 1 ] 表示第 i 天是 “可卖出” 状态,此时的最大利润。
dp[ i ][ 2 ] 表示第 i 天是 “冷冻” 状态,此时的最大利润。
2. 状态转移方程
我们一个一个分析状态表示:
首先是买入状态,怎么样让第 i 天进入买入状态?
如果 i - 1 天结束是买入状态(买过股票)那就已经是买入状态,
如果 i - 1 天结束是可交易状态(可以卖股票但没买)那只要这天买入,就可以进入买入状态,
如果 i - 1 天结束是冷冻状态(就是卖出的后一天)这样就不能进入买入状态。
然后是冷冻状态,怎么样让第 i 天进入冷冻状态?
如果 i - 1 天结束是买入状态,那只要这天卖出,就能进入冷冻状态,
如果 i - 1 天结束是可交易状态,那只要这天卖了,也能进入冷冻状态,
如果 i - 1 天结束是冷冻状态,那第 i 天结束不可能是冷冻状态,因为没东西可以卖了。
然后是可交易状态,怎么样让第 i 天进入可交易状态?
如果 i - 1 天结束是买入状态,那就不是可交易状态,而是买入状态。
如果 i - 1 天结束是可交易状态,那也只需要啥都不干就是可交易状态,
如果 i - 1 天结束是冷冻状态,那也只需要啥都不干就是可交易状态。
所以我们根据上面的分析来写状态转移方程:
dp[ i ][ 0 ] = max( dp[ i - 1 ][ 0 ],dp[ i - 1 ][ 1 ] - p[ i ] )
dp[ i ][ 1 ] = max( dp[ i - 1 ][ 1 ],dp[ i - 1 ][ 2 ] )
dp[ i ][ 2 ] = dp[ i - 1 ][ 0 ] + p[ i ]
3. 初始化
我们只需要把 dp[ 0 ][ 0 ] 初始化成 -p[ 0 ] 即可,因为买入了所以最大利润就是一个负值。
4. 填表顺序
从左往右,依次填写三个表即可。
5. 返回值
其实就是:max( dp[ n - 1 ][ 1 ],dp[ n - 1 ][ 2 ] )
第一种买入的情况不考虑,因为都买入了,肯定不会是最大利润。
3. 代码编写
class Solution {
public:int maxProfit(vector<int>& prices) {int n = prices.size();vector<vector<int>> dp(n, vector<int>(3));dp[0][0] = -prices[0];for(int i = 1; i < n; i++) {dp[i][0] = max(dp[i - 1][0], dp[i - 1][1] - prices[i]);dp[i][1] = max(dp[i - 1][1], dp[i - 1][2]);dp[i][2] = dp[i - 1][0] + prices[i];}return max(dp[n - 1][1], dp[n - 1][2]);}
};
写在最后:
以上就是本篇文章的内容了,感谢你的阅读。
如果感到有所收获的话可以给博主点一个赞哦。
如果文章内容有遗漏或者错误的地方欢迎私信博主或者在评论区指出~
相关文章:
【学会动态规划】最佳买卖股票时机含冷冻期(15)
目录 动态规划怎么学? 1. 题目解析 2. 算法原理 1. 状态表示 2. 状态转移方程 3. 初始化 4. 填表顺序 5. 返回值 3. 代码编写 写在最后: 动态规划怎么学? 学习一个算法没有捷径,更何况是学习动态规划, 跟我…...
随机RSI震荡指标公式(StochRSI),RSI和KDJ二合一
随机RSI震荡指标(StochRSI)是由图莎尔钱德和斯坦利克罗发明的一种摆动指标,结合了相对强弱指标(RSI)和随机指标(KDJ)的原理,目的是提高灵敏度,解决RSI难以达到超买超卖区的问题,以便…...
轻松搭建酒店小程序
酒店小程序的制作并不需要编程经验,只需要按照以下步骤进行操作,就能很快地搭建自己的小程序商城。 第一步,注册登录账号进入操作后台,找到并点击【商城】中的【去管理】进入商城的后台管理页面,然后再点击【小程序商城…...
算法通过村——Hash和队列问题解析
算法的备胎Hash和找靠山的队列 备胎Hash Hash,不管是算法,还是在工程中都会大量使用。很多复杂的算法问题都用Hash能够轻松解决,也正是如此,在算法例就显得没什么思维含量,所以Hash是应用里的扛把子,但在算…...
租赁类小程序定制开发|租赁管理系统源码|免押租赁系统开发
随着互联网的发展,小程序成为了一种重要的移动应用开发方式。租赁小程序作为其中的一种类型,可以为很多行业提供便利和创新。下面我们将介绍一些适合开发租赁小程序的行业。 房屋租赁行业:租房小程序可以帮助房东和租户快速找到合适的租赁…...
后端进阶之路——浅谈Spring Security用户、角色、权限和访问规则(三)
前言 「作者主页」:雪碧有白泡泡 「个人网站」:雪碧的个人网站 「推荐专栏」: ★java一站式服务 ★ ★前端炫酷代码分享 ★ ★ uniapp-从构建到提升★ ★ 从0到英雄,vue成神之路★ ★ 解决算法,一个专栏就够了★ ★ 架…...
Mac 安装不在 Apple 商店授权的应用程序
文章目录 一、场景介绍二、实操说明 一、场景介绍 在日常的工作生活中,发现一些好用的应用程序,但是出于某些原因,应用程序的开发者并没有将安装包上架到苹果商店。 那么这些优秀的应用程序下载安装以后就会出现如下弹框被拒之门外 二、实操…...
【MyBatis】MyBatis把空字符串转换成0的问题处理方案(96)
先看问题: Postman入参: MyBatis采用map循环插入: // Mapper接口层void addPar(Param(value "question") Map<String, Object> paramMap);<!-- 新增:参数 --><insert id"addPar" parameterType"map">INSERT IGNO…...
OpenLayers实战,OpenLayers获取移动端精确定位,OpenLayers适配App混合H5方式调用手机定位位置并定位到指定点
专栏目录: OpenLayers实战进阶专栏目录 前言 本章讲解OpenLayers如何获取移动端精确定位位置。不使用任何native本地方法,只使用纯js实现。 本篇文章适用于App混合H5方式调用手机精确定位,打包时需要选择GPS位置权限,手机获取定位过程中会弹出是否允许定位的权限提示。 …...
Go指针取址问题:循环后每次都拿到相同内容
例子: func main() {yourList : [...]int{1, 2, 3}yourMap1 : make(map[int]*int)yourMap2 : make(map[int]*int)for key, value : range yourList {// 修改前yourMap1[key] &value// 修改后tmp : valueyourMap2[key] &tmpfmt.Println(value, &value…...
用Rust实现23种设计模式之简单工厂
在 Rust 中,可以使用结构体和 trait 来实现工厂方法模式。工厂方法模式是一种创建型设计模式,通过定义一个创建对象的接口,让子类决定实例化哪个类。下面是一个简单的示例,展示了如何使用 Rust 实现工厂方法模式: // …...
SpringBoot + minio实现分片上传、秒传、续传
什么是minio MinIO是一个基于Go实现的高性能、兼容S3协议的对象存储。它采用GNU AGPL v3开源协议,项目地址是https://github.com/minio/minio。 引用官网: MinIO是根据GNU Affero通用公共许可证v3.0发布的高性能对象存储。它与Amazon S3云存储服务兼容…...
logback 里面设置 自动删除3天之前的日志
目录 1 实现 1 实现 要实现达到一定大小后将日志文件压缩,并删除三天前的日志数据,可以结合使用 SizeAndTimeBasedRollingPolicy 滚动策略和 DeleteOlderThan 选项来配置。下面是一个示例配置,实现日志文件达到一定大小后进行滚动和压缩&…...
对于数据库查询索引和查字典索引的理解
之前面试问过我对于数据库索引的理解,这个问题不是具体的问题太宽泛,面试官也没进行引导,我不知道怎么回答,下面是结合查字典进行理解。 查字典 拿查字典举例,知道一个字怎么写但是不知道具体的意思以及发音ÿ…...
git删除已经提交的大文件
当你不小心把一个巨大的二进制文件提交到git仓库的时候,此时删除再提交也没有用了,大文件已经在仓库中留底了。另外比如需要删除某个需要保密的文件,都是相同的解决办法。 我本来想着把dll放在三方库里面提交到仓库里,省得在不同…...
【数据分析】pandas 一
目录 一,pandas简介: 二,pandas数据结构Series简介: 2.1 data为ndarray 2.2 data为字典 三,Serise切片操作: 四,Series性质: 4.1 Series类似于numpy,字典 4.2 矢量化操作和标…...
题解 | #G.Gcd# 2023牛客暑期多校6
G.Gcd 数论 题目大意 给定一个包含两个非负数的初始集合 S { x , y } S\{x,y\} S{x,y} 每次操作可以选定其中不相等的两个数 a , b a,b a,b ,并将 a − b a-b a−b 或 g c d ( a , b ) gcd(a,b) gcd(a,b) 置入集合 S S S ,其中 g c d ( 0 , a …...
苍穹外卖day10——订单状态定时处理(Spring Task)、来单提醒和客户催单(WebSocket)
预期效果 对于超时没处理的需要定时程序处理。基于SpringTask实现。 来单提醒和客户催单。基于WebSocket实现。 Spring Task 介绍 Cron表达式 周几通常不能和日一起指定。 cron表达式在线生成器 在线Cron表达式生成器 入门案例 创建定时任务类 /*** 定义定时任务类*/ Slf4j…...
【多线程初阶】多线程案例之单例模式
文章目录 前言1. 什么是单例模式2. 饿汉模式3. 懒汉模式 --- 单线程版4. 懒汉模式 --- 多线程版5. 懒汉模式 --- 多线程改进版总结 前言 本文主要给大家讲解多线程的一个重要案例 — 单例模式. 关注收藏, 开始学习吧🧐 1. 什么是单例模式 单例模式是一种很经典的…...
跨境选品怎么选?建议独立站卖家收下这份利基产品查找攻略!
跨境电商平台现在可谓是火热发展中,独立站出海风口,其实选择的机会还真不少,相比国内电商的发展势头,看得出来,未来跨境电商的大门,对你而言,敞开着。选品这事儿,就像你上战场前挑选…...
SQL如何统计分组中占比超过一定阈值的数据_HAVING过滤聚合
WHERE在分组前过滤行,HAVING在分组后过滤组;占比类条件必须用HAVING或窗口函数实现,WHERE无法使用聚合函数。WHERE 和 HAVING 的分工必须分清WHERE 在分组前过滤行,HAVING 在分组后过滤组。想筛“某组占比 > 80%”这种条件&…...
告别简单池化:用PyTorch实现Attention MIL,让模型学会‘聚焦’关键实例
告别简单池化:用PyTorch实现Attention MIL,让模型学会‘聚焦’关键实例 在医学图像分析或文本分类任务中,我们常常遇到这样的场景:单个样本由多个实例组成(如病理切片中的多个细胞区域、文档中的多个句子段落ÿ…...
GHelper:轻量级ROG笔记本性能优化工具,告别臃肿的官方控制软件
GHelper:轻量级ROG笔记本性能优化工具,告别臃肿的官方控制软件 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, F…...
Sunshine终极指南:打造你的个人游戏串流服务器
Sunshine终极指南:打造你的个人游戏串流服务器 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine Sunshine是一款开源的自托管游戏串流服务器,专为Moonlight客…...
统信UOS与麒麟Kylin OS下WeekToDo的高效任务管理指南
1. 为什么选择WeekToDo管理任务 在国产操作系统统信UOS和麒麟Kylin OS上,找到一款既轻量又高效的任务管理工具并不容易。WeekToDo恰好填补了这个空白,它就像你桌面上的一张便利贴,但比便利贴智能得多。我用了三个月后,工作效率提升…...
从Kaggle比赛到公司项目:我是如何用Baseline快速启动,靠Benchmark评估进度,并追踪SOTA保持竞争力的
从Kaggle实战到工业落地:Baseline快速验证、Benchmark科学对标与SOTA持续进化的方法论 去年接手电商评论情感分析项目时,业务方只丢来一句"希望准确率至少比现有系统高15%"。面对数百万条未标注的评论数据,我用了72小时就给出了可行…...
DVWA实战:文件包含漏洞的攻防博弈与场景化利用
1. 文件包含漏洞初探:从原理到危害 第一次接触文件包含漏洞时,我正调试一个简单的PHP网站。当时发现修改URL参数就能读取服务器上的任意文件,那种"原来系统这么脆弱"的震惊感至今难忘。文件包含漏洞本质上是一种代码注入技术&#…...
人脸识别模型效果展示:Retinaface+CurricularFace实测案例分享
人脸识别模型效果展示:RetinafaceCurricularFace实测案例分享 1. 模型效果概览 RetinafaceCurricularFace组合模型在人脸识别领域展现出卓越性能。这套方案通过Retinaface实现高精度人脸检测,再结合CurricularFace进行深度特征提取与比对,在…...
Qwen3-Reranker效果展示:政府公文写作中政策依据与原文段落匹配
Qwen3-Reranker效果展示:政府公文写作中政策依据与原文段落匹配 1. 引言:政策公文写作的精准匹配挑战 在政府公文写作过程中,准确引用相关政策依据是确保文件权威性和合规性的关键环节。传统的检索方式往往面临语义理解不深、匹配精度不足的…...
Web Scraper完整指南:零代码网页数据抓取终极解决方案
Web Scraper完整指南:零代码网页数据抓取终极解决方案 【免费下载链接】web-scraper-chrome-extension Web data extraction tool implemented as chrome extension 项目地址: https://gitcode.com/gh_mirrors/we/web-scraper-chrome-extension Web Scraper是…...
