Day 50[补档] |● 123.买卖股票的最佳时机III ● 188.买卖股票的最佳时机IV

123.买卖股票的最佳时机III

class Solution {
public:int maxProfit(vector<int>& prices) {if(prices.size() == 0) return 0;vector<vector<int>> dp(prices.size(), vector<int>(5,0));//dp[i][j] 表示根据j的方法数下,第i天时候最大的金额量dp[0][0] = 0; //无操作dp[0][1] = -prices[0];//第一次持有dp[0][2] = 0;//第一次卖出dp[0][3] = -prices[0];//第二次持有dp[0][4] = 0;//第二次卖出for(int i = 1; i < prices.size(); i++){dp[i][0] = dp[i-1][0];dp[i][1] = max(dp[i-1][1], dp[i-1][0]-prices[i]);dp[i][2] = max(dp[i-1][2], dp[i-1][1] + prices[i]);dp[i][3] = max(dp[i-1][3], dp[i-1][2]-prices[i]);dp[i][4] = max(dp[i-1][4], dp[i-1][3] + prices[i]);}return dp[prices.size()-1][4];}
};

具体思路:

        既然是2次买卖,则根据状态的延续,会存在上述5个状态(虽然关于0状态没必要单独写,只是为了好理解)。则依次解释每个状态计算:

dp[i][0] = dp[i-1][0] :

        第i天不作操作当然是由前面不作操作的状态延续来;

dp[i][1] = max(dp[i-1][1], dp[i-1][0]-prices[i]):

        第i天第一次持有股票的状态来源要么是前i-1天就已经持有股票的状态,要么则是第i天买入股票,那么此状态只能通过前i-1天无操作才能得来。

dp[i][2] = max(dp[i-1][2], dp[i-1][1] + prices[i]);

        第i天第一次卖出的状态要么是在i-1天之前已经卖出了,而这个状态一直持续到现在,或者是选择第i天将股票卖出,而当天卖出前提是我已经持有此股票,则状态只能是由i-1天以前一直持有此股票,即状态1的情况下,再卖出此股票即加上当前时刻股票价格即可。

后面其实一回事,只是3需要注意的一点就是,因为题目说每次必须卖完才能买卖下一次股票,则第2次购买股票,即状态码为3,需要再dp[i-1][2],即上一次操作已经完成的状态下进行。后面都一样了。

还有关于dp数组初始化的问题,行数如何选取这一块,size()是否需要+1,得看递推中是否存在需要多定义一行这一情况,比较常见的就是前几个数的可以满足获得dp值的这一情况,这种可能需要定义前0个数的状态,则这种就需要初始化 size()+1.

188.买卖股票的最佳时机IV

class Solution {
public:int maxProfit(int k, vector<int>& prices) {vector<vector<int>> dp(prices.size(),vector<int>(2*k+1,0));for(int j = 1; j < 2*k; j += 2){dp[0][j] = -prices[0];}// dp[0][0] = 0;// dp[0][1] = -prices[0];//持有股票的状态// dp[0][2] = 0;//卖出股票的状态for(int j = 1; j < prices.size(); j++){for(int i = 0; i < 2*k; i += 2){dp[j][i+1] = max(dp[j-1][i+1],dp[j-1][i] - prices[j]);//持有dp[j][i+2] = max(dp[j-1][i+2], dp[j-1][i+1] + prices[j]);//卖出}}return dp[prices.size()-1][2*k];}
};

具体思路:

        因为是k此买卖,则就是上述题目的变种,需要在买卖状态添加一个0无操作的状态,则总共K次买卖有 2*k+1种状态,别忘了对第一天所有状态都要初始化,这个我忘了!

        其次后面就是对所有状态进行更新,没啥好讲的,跟上面一样,只是抽象化了,还有最后return的范围注意看,因为初始化是2k+1,则最终是为了获得下标为2k的数据,因为多的1是0下标。

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

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

相关文章

win11配置Mask DINO小白踩坑记录

win11配置Mask DINO踩坑记录 1 准备工作2 创建python环境和安装detectron22.1 安装前提2.2 安装流程2.2.1 cl.exe的错误2.2.2 SetuptoolsDeprecationWarning的错误 3 MaskDINO运行3.1 运行demo 前情提要&#xff1a;需要复现Mask DINO&#xff0c;但是实验室没有Linux的电脑&am…

keycloak18.0.0==本地源码启动

github下载源码&#xff0c; 版本18.0.0 java和maven的版本如下 E:\keycloak-18.0.0>java -version java version "21.0.1" 2023-10-17 LTS Java(TM) SE Runtime Environment (build 21.0.112-LTS-29) Java HotSpot(TM) 64-Bit Server VM (build 21.0.112-LTS-…

Wince NK.BIN文件格式

nk.bin文件格式 开始7个字节为 42 30 30 30 46 46 0A 即“B000FF\x0A”&#xff0c;以次来判别文件类型。 接下来4字节&#xff08;DWORD&#xff09;表示ImageStart, 4字节表示ImageLength 如7字节后的8字节分别为&#xff1a;00 00 00 60 9C FA 33 01 则表示ImageStart0x600…

【SpringBoot3.x教程05】SpringBoot与关系型数据库的整合

前言&#xff1a;常用的ORM框架有哪些 JdbcTemplate JdbcTemplate 是Spring框架提供的一个JDBC抽象库&#xff0c;旨在简化传统的JDBC操作&#xff0c;避免了繁琐的JDBC代码和数据库资源的手动处理。通过JdbcTemplate&#xff0c;开发者可以更加专注于业务逻辑而不是数据库的连…

【网站项目】308学生档案管理系统

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

如何用Python3自撰一个简单的后端框架

不使用任何现有的后端框架来创建一个Python 3的后端框架是一个相当复杂的任务,因为它涉及到许多Web开发的基础知识,比如HTTP协议处理、路由、中间件、请求和响应处理等。然而,我们可以从最基本的概念开始,逐步构建一个简单的后端框架。 以下是一个非常基础的指南,用于创建…

Spring Webflux 详解

目录 0、组件对比 1、WebFlux 1、引入 2、Reactor Core 1、HttpHandler、HttpServer 3、DispatcherHandler 1、请求处理流程 4、注解开发 1、目标方法传参 2.返回值写法 5、文件上传 6、错误处理 7、RequestContext 8、自定义Flux配置 9、Filter WebFlux&am…

2024武汉国际氢能源与燃料电池展将在8月盛大开幕!

2024武汉国际氢能源及燃料电池产业博览会 同期举办&#xff1a;2024世界汽车制造技术暨智能装备博览会 时间&#xff1a;2024.8.14-16 地点&#xff1a;武汉国际博览中心 邀请函 主办单位&#xff1a; 湖北省汽车行业协会 湖北省机械行业联合会 湖北省汽车产业技术创新联…

查找数组元素相同的最后一组数组的第一个下标

题目 面试过程中&#xff0c;被问到这道面试题&#xff0c;做个记录&#xff1a; 有一组数组x&#xff1a; x{“11”,”aa”} 要比较的数组y是&#xff1a; y{“11”,”aa”,“11”,”aa”} y1{“11”,”aa”,“11”,”res”,”aa”} y2 {“11”,”11”,“11”,”aa”} 需…

为树莓派5编译Android14源码

为树莓派5编译Android14源码 1. 软硬件要求 官方推荐配置: https://source.android.google.cn/docs/setup/start/requirements?hl=zh-cn ubuntu22.04 虚拟机内存最低 16GB磁盘最低 360GB2. 安装依赖工具 官方文档:https://source.android.google.cn/docs/setup/start/init…

jieba模块中文分词应用场景案例

jieba 是一个在 Python 中广泛使用的中文分词库。由于其高效、准确和易用&#xff0c;jieba 在自然语言处理领域有着广泛的应用。下面我将通过一个简单的案例来展示 jieba 在中文分词中的应用场景。 案例&#xff1a;文本分类 假设我们有一个简单的文本分类任务&#xff0c;需…

Linux 之二:CentOS7 的 IP 常用命令和配置及 xshell 基本使用方法

1. 进入虚拟机 点击右键---进入终端--输入 ip adrr 或 ifconfig 查看ip地址 下面输入命令 ifconfig&#xff08;注意&#xff1a;不是 ipconfig &#xff09; 或 ip addr 来查看当前系统 IP 查看到IP 后&#xff0c;比如&#xff1a;上面是 192.168.184.137 1.1 IP 常用命令…

LeetCode142题:环形链表II(python3)

代码思路&#xff1a; 双指针的第一次相遇&#xff1a; 设两指针 fast&#xff0c;slow 指向链表头部 head 。 令 fast 每轮走 2 步&#xff0c;slow 每轮走 1 步。 fast 指针走过链表末端&#xff0c;说明链表无环&#xff0c;此时直接返回 null。 如果链表存在环&#xff0c;…

web学习笔记(二十六)

目录 1.JS执行队列 1.1JS是单线程 1.2Web Worker 1.3同步和异步 1.4JS执行机制 2.location对象 2.1什么是location对象 2.2url包含的信息 2.3location对象属性 2.4location对象的方法 3.navigator对象和history对象 3.1navigator对象 3.2history对象 1.JS执行队…

在Jupyter Notebook中安装第三方库

pip vs. conda pip 可以在所有环境下安装python包。conda 可以在conda环境下安装所有包。 如果你已经安装了python&#xff0c;那么这个选择对你来说是非常容易的&#xff1a; 如果你是用Anaconda或者Miniconda安装的python&#xff0c;那么请使用conda命令来安装python包。如…

原来我不会递归的原因是不会调试

visual 2022 关于debug和release的区别&#xff0c; 原谅我现在才知道 飞机降落--蓝桥 #include<iostream> using namespace std; struct node {int a, b, c; }q[11];int t, n;bool book[11]; // 标记第 i 架飞机是否降落bool dfs(int num, int last) {if (num n) r…

【MogDB】实战MogDB数据库适配Halo博客系统1.6版本(基于springframework+hibernate+HikariPool)

前言 前一篇文章说了MogDB适配Halo,【MogDB】将流行的博客系统Halo后端的数据库设置为MogDB,但是适配的是2.x版本&#xff0c;由于2.x版本已经引入了对postgresql的支持&#xff0c;而MogDB对于postgresql有很好的兼容性&#xff0c;因此适配起来很简单。但是由于halo2.x的版本…

初识JS

目录 javascript的作用: 浏览器如何执行JS代码&#xff1a; JS的三部分组成&#xff1a; ECMAScript: DOM: BOM: JS的三种书写导入方式&#xff1a; JS注释&#xff1a; JS的输入输出语句&#xff1a; JS变量,数据&#xff1a; 变量的使用&#xff1a; 声明变量&…

Linux的包管理和软件仓库常见问题有哪些?怎么解决

Linux的包管理和软件仓库在使用过程中可能会遇到一些问题&#xff0c;这些问题通常涉及软件的安装、更新、依赖关系、仓库配置等方面。以下是一些常见问题及其解决方法&#xff1a; 1. **软件包依赖问题**&#xff1a; - **问题**&#xff1a;在安装软件时&#xff0c;系统…

嵌入式学习第二十五天!(网络的概念)

网络&#xff1a; 可以用来&#xff1a;数据传输、数据共享 1. 网络协议模型&#xff1a; 1. OSI协议模型&#xff1a; 应用层实际收发的数据表示层发送的数据是否加密会话层是否建立会话连接传输层数据传输的方式&#xff08;数据包&#xff0c;流式&#xff09;网络层数据的…