代码随想录算法训练营第四十九天| 123.买卖股票的最佳时机III,188.买卖股票的最佳时机IV

目录

题目链接:123.买卖股票的最佳时机III

思路

代码

题目链接:188.买卖股票的最佳时机IV

思路

代码

总结


题目链接:123.买卖股票的最佳时机III

思路

        与之前买卖股票不同的是本题要求最多买卖两次,那么dp数组以及递推公式都有所改变。

        ①dp数组,dp[i][j]表示第i天剩余的最大金币,j表示操作状态:

                0表示无操作

                1表示第一次持有股票

                2表示第一次不持有股票

                3表示第二次持有股票

                4表示第二次不持有股票

                五种状态都是依次连续的:

                        无操作->第一次持有->第一次不持有->第二次持有->第二次不持有

        ②递推公式,要包含上述五种状态的更新

                dp[i][0] = dp[i-1][0] 无操作与前一天保持一样

                dp[i][1] = max(dp[i-1][1], dp[i-1][0] - price[i]) 可能之前就买过;如果没买,说明之前都是无操作的状态

                dp[i][2] = max(dp[i-1][2], dp[i-1][1] + price[i]) 可能之前就卖了;如果没卖,说明第一次买的还在,今天卖

                dp[i][3] = max(dp[i-1][3], dp[i-1][2] - price[i]) 可能进行了一次买卖后,第二次买入了;如果没买,说明已经进行了第一次的股票买卖,还没进行第二次

                dp[i][4] = max(dp[i-1][4], dp[i-1][3] + price[i]) 可能将第二次买的股票卖了,或者今天卖

        ③dp数组初始化

                dp[0][0] = 0 无操作就是0

                dp[0][1] = -price[i] 第一天持有,表示第一天买入,减去当天股票价格

                dp[0][2] = 0 第一天不持有,表示没有买入,还是0

                dp[0][3] = -price[i] 与第一次情况相同,可以认为第一天买了又卖了,现在是第二次

                dp[0][4] = 0 第二次不持有,表示没有买入,还是0

        ④遍历顺序,正序遍历,因为所有的状态更新都依赖于前一天

        ⑤推导dp数组

代码

class Solution {
public:// dp数组第一维表示第i天,第二维表示状态// 0表示无操作// 1表示第一次持有// 2表示第一次不持有// 3表示第二次持有// 4表示第二次不持有int maxProfit(vector<int>& prices) {int len = prices.size();if (len == 1)return 0;vector<vector<int>> dp(len, vector<int>(5, 0));// dp数组初始化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 < len; 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[len - 1][4];}
};

题目链接:188.买卖股票的最佳时机IV

思路

        原理与123.买卖股票的最佳时机Ⅲ相同,可以买卖k次,创建dp数组时,第二维空间2k+1,初始化以及状态更新时用for循环。

代码

class Solution {
public:// dp数组第一维表示第i天// 第二维奇数表示第j次持有,偶数表示第j次不持有,0表示无操作int maxProfit(int k, vector<int>& prices) {int len = prices.size();if (len == 1)return 0;// 每次交易都包含持有和未持有两种状态,还有0表示无操作,所以共计2*k+1个状态int s = 2 * k + 1;vector<vector<int>> dp(len, vector<int>(s, 0));// dp数组初始化,j从到2*kfor (int j = 0; j < s; j++) {if (j % 2 == 1) {dp[0][j] = -prices[0];} else {dp[0][j] = 0;}}// dp数组状态更新for (int i = 1; i < len; i++) {dp[i][0] = dp[i - 1][0]; // 无操作单独赋值for (int j = 1; j < s; j++) {// 奇数表示持有,偶数表示未持有// 每种状态都由前一天推导而来,涉及前一天的当前状态和前一种状态if (j % 2 == 1) {dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - 1] - prices[i]);} else {dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - 1] + prices[i]);}}}return dp[len - 1][2 * k];}
};

总结

        ①买卖股票Ⅰ和Ⅱ分别是只能买卖一次和不限次数的买卖;买卖股票Ⅲ和Ⅳ分别是只能买卖两次和买卖k次。相同点是当天的状态只能由昨天推导而来,不同点是状态的多少

        ②看了买卖股票Ⅲ的题解,AC后,单独完成了买卖股票Ⅳ,规律性很强

        ③在做这类题时,最重要的是搞清楚dp数组的含义,并且要包含所有的状态

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

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

相关文章

攻击者正在利用AI,对保险公司发起大规模欺诈

保险欺诈一直是保险行业面临的重要挑战之一&#xff0c;尤其随着技术的进步&#xff0c;欺诈者也在不断更新其手段&#xff0c;利用AI技术&#xff0c;包括生成式模型、机器学习和数据分析工具等欺骗保险公司&#xff0c;而AI技术的应用正成为他们的新工具&#xff0c;使其犯罪…

如何打造个人IP?

打造个人IP&#xff08;Intellectual Property&#xff09;是当今社会中越来越受到关注的话题。个人IP指的是个人在某个领域内所拥有的独特的、具有商业价值的知识、技能、品牌和影响力。为什么要打造个人IP&#xff1f;如何打造个人IP&#xff1f;下面我将为您详细解答。 首先…

Navicat连接远程数据库时,隔一段时间不操作出现的卡顿问题

使用 Navicat 连接服务器上的数据库时&#xff0c;如果隔一段时间没有使用&#xff0c;再次点击就会出现卡顿的问题。 如&#xff1a;隔一段时间再查询完数据会出现&#xff1a; 2013 - Lost connection to MySQL server at waiting for initial communication packet, syste…

LinkedList链表

LinkedList 的全面说明 LinkList底层实现了双向链表和双端队列特点可以添加任意元素&#xff08;元素可以重复&#xff09;&#xff0c;包括null线程不安全&#xff0c;没有实现同步 LinkedList 的底层操作机制 LinkedList底层维护了一个双向链表LinkList中维护了两个属性fi…

【算法入门赛】A.坐标变换(推荐学习)C++题解与代码

比赛链接&#xff1a;https://www.starrycoding.com/contest/8 题目描述 武汉市可以看做一个二维地图。 牢 e e e掌握了一项特异功能&#xff0c;他可以“瞬移”&#xff0c;每次瞬移需要分别设定 x x x和 y y y的偏移量 d x dx dx和 d y dy dy&#xff0c;瞬移完成后位置会…

【Fastadmin】表格列改input框输入编辑,以排序权重为例

目录 1.自定义权重排序,以字段sort为例 js列代码 在// 初始化表格table.bootstrapTable({ });的后面添加事件 api里面增加formatter方法,如果存在角色权限问题,控制器添

谷歌外链怎么发?

既要数量也要质量&#xff0c;要保证你的链接广泛分布&#xff0c;在数量上&#xff0c;确实需要你的链接在各种平台上有所展现&#xff0c;这样能提升你网站的知名度和曝光率&#xff0c;但是&#xff0c;光有数量是不够的&#xff0c;如果这些链接的内容不行&#xff0c;那对…

ARIMA模型在河流水质预测中的应用_含代码

#水质模型 #时间序列 #python应用 ARIMA 时间序列模型简介 时间序列是研究数据随时间变化而变化的一种算法&#xff0c;是一种预测性分析算法。它的基本出发点就是事物发展都有连续性&#xff0c;按照它本身固有的规律进行。ARIMA(p,d,q)模型全称为差分自回归移动平均模型 (A…

SSH文件传输

一、设置SSH密钥对&#xff0c;实现记住密码 要避免每次使用scp或ssh时都输入密码&#xff0c;你可以设置SSH密钥对&#xff08;一对公钥和私钥&#xff09;&#xff0c;并将公钥添加到远程服务器上。这样&#xff0c;你的系统可以通过密钥自动验证身份&#xff0c;而无需手动…

Blazor入门-基础知识+vs2022自带例程的理解

参考&#xff1a; Blazor 教程 - 生成首个应用 https://dotnet.microsoft.com/zh-cn/learn/aspnet/blazor-tutorial/intro Blazor基础知识&#xff1a;Visual Studio 2022 中的Blazor开发入门_vs2022 blazor webassembly-CSDN博客 https://blog.csdn.net/mzl87/article/detail…

NSSCTF | [SWPUCTF 2021 新生赛]jicao

打开题目&#xff0c;发现高亮显示了一个 php 脚本 这是脚本的内容 <?php highlight_file(index.php); include("flag.php"); $id$_POST[id]; $jsonjson_decode($_GET[json],true); if ($id"wllmNB"&&$json[x]"wllm") {echo $flag;…

idea中数据库的连接(保姆级)

点击idea中的database 然后再点击加号 创建 然后选择第一栏data source 再选择mysql 然后选择数据库的连接方式 再输入密码 这里我们本来就是localhost所有就不用改 选择端口号 然后点击Test Connection 测试连接 第一次连接会下载连接的文件 我们只需要 等待它下载完成就好了 …

文本批量操作指南:文本合并技巧,批量处理大量文本的方法

在数字化时代&#xff0c;文本处理成为我们日常生活和工作中不可或缺的一部分。无论是整理文档、数据分析还是内容创作&#xff0c;我们都需要处理大量的文本数据。为了提升工作效率&#xff0c;掌握文本批量操作和合并的技巧变得尤为重要。本文将为您提供一份详细的文本批量操…

机器学习算法应用——CART决策树

CART决策树&#xff08;4-2&#xff09; CART&#xff08;Classification and Regression Trees&#xff09;决策树是一种常用的机器学习算法&#xff0c;它既可以用于分类问题&#xff0c;也可以用于回归问题。CART决策树的主要原理是通过递归地将数据集划分为两个子集来构建决…

力扣 256. 粉刷房子 LCR 091. 粉刷房子 python AC

动态规划 class Solution:def minCost(self, costs):row, col len(costs), 3dp [[0] * col for _ in range(row 1)]for i in range(1, row 1):for j in range(col):dp[i][j] costs[i - 1][j - 1]if j 0:dp[i][j] min(dp[i - 1][1], dp[i - 1][2])elif j 1:dp[i][j] m…

【QT教程】QT6硬件高级编程实战案例 QT硬件高级编程

QT6硬件高级编程实战案例 使用AI技术辅助生成 QT界面美化视频课程 QT性能优化视频课程 QT原理与源码分析视频课程 QT QML C扩展开发视频课程 免费QT视频课程 您可以看免费1000个QT技术视频 免费QT视频课程 QT统计图和QT数据可视化视频免费看 免费QT视频课程 QT性能优化视频免…

【GoLang基础】通道(channel)是什么?

问题引出&#xff1a; Go语言中的通道&#xff08;channel&#xff09;是什么&#xff1f; 解答&#xff1a; 通道&#xff08;channel&#xff09;是 Go 语言中用于协程&#xff08;goroutine&#xff09;之间通信和同步的机制。通道提供了一种安全、简单且高效的方式&#x…

idea运行SpringBoot项目爆红提示出现:Java HotSpot(TM) 64-Bit Server VM warning...让我来看看~

在运行SpringBoot项目的时候&#xff0c;发现总有这个警告提示出现&#xff0c;有点强迫症真的每次运行项目都很难受啊&#xff01;那么今天便来解决这个问题&#xff01; 先来看一下提示内容&#xff1a;Java HotSpot(TM) 64-Bit Server VM warning: Options -Xverify:none an…

FreeRTOS标准库例程代码

1.设备STM32F103C8T6 2.工程模板 单片机: 部分单片机的程序例程 - Gitee.comhttps://gitee.com/lovefoolnotme/singlechip/tree/master/STM32_FREERTOS/1.%E5%B7%A5%E7%A8%8B%E6%A8%A1%E6%9D%BF 3.代码 1-FreeRTOS移植模板 #include "system.h" #include "…

C语言编程中布尔设置位掩码示例

在C语言编程中&#xff0c;当你想使用整数&#xff08;通常是unsigned int或uint8_t, uint16_t, uint32_t等&#xff09;的位来存储多个布尔设置时&#xff0c;你会使用位掩码。每个设置对应于整数中的一个位&#xff0c;你可以通过位操作&#xff08;如按位与&、按位或|、…