当前位置: 首页 > news >正文

力扣_动态规划1—买卖股票的最佳时机

题目

给定一个数组,它的第 i 个元素是一支给定的股票在第 i 天的价格。
设计一个算法来计算你所能获取的最大利润。你最多可以完成 两笔 交易。
注意:你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。

方法—动态规划

  • 由于我们最多可以完成两笔交易,因此在任意一天结束之后,我们会处于以下五个状态中的一种:
    • 未进行过任何操作;(利润为0,忽略)
    • 只进行过一次买操作;
    • 进行了一次买操作和一次卖操作,即完成了一笔交易;
    • 在完成了一笔交易的前提下,进行了第二次买操作;
    • 完成了全部两笔交易。
  • 四种状态的最大利润分别记为 d p 1 , d p 2 , d p 3 , d p 4 dp_1, dp_2, dp_3, dp_4 dp1,dp2,dp3,dp4
  • 状态转移:
    • d p 1 = m a x ( d p 1 , − p r i c e s [ i ] ) dp_1 = max(dp_1, -prices[i]) dp1=max(dp1,prices[i]) # 不做任何操作或者今天买
    • d p 2 = m a x ( d p 2 , d p 1 + p r i c e s [ i ] ) dp_2 = max(dp_2, dp_1+prices[i]) dp2=max(dp2,dp1+prices[i]) # 不做任何操作或者今天卖
    • d p 3 = m a x ( d p 3 , d p 2 − p r i c e s [ i ] ) dp_3 = max(dp_3, dp_2-prices[i]) dp3=max(dp3,dp2prices[i]) # 不做任何操作或者今天买
    • d p 4 = m a x ( d p 4 , d p 3 + p r i c e s [ i ] ) dp_4 = max(dp_4, dp_3+prices[i]) dp4=max(dp4,dp3+prices[i]) # 不做任何操作或者今天卖
  • 初始状态
    • d p 1 = − p r i c e s [ 0 ] dp_1 = -prices[0] dp1=prices[0] # 第一天买入
    • d p 2 = 0 dp_2 = 0 dp2=0 # 第一天买入并立即卖掉
    • d p 3 = − p r i c e s [ 0 ] dp_3 = -prices[0] dp3=prices[0] # 第一支卖了后立即买入第二支
    • d p 4 = 0 dp_4 = 0 dp4=0 # 立即卖掉第二支

代码

class Solution {
public:int maxProfit(vector<int>& prices) {int n = prices.size();int dp1 = -prices[0]; // 持有第一支int dp2 = 0; // 卖或已经卖了第一支int dp3 = -prices[0]; // 持有第二支int dp4 = 0; // 卖或已经卖了第二支int ret = 0;for(int i = 1; i < n; i++){dp1 = max(dp1, -prices[i]);dp2 = max(dp2, prices[i]+dp1);dp3 = max(dp3, dp2-prices[i]);dp4 = max(dp4, prices[i]+dp3);}return dp4;}
};

相关文章:

力扣_动态规划1—买卖股票的最佳时机

题目 给定一个数组&#xff0c;它的第 i 个元素是一支给定的股票在第 i 天的价格。 设计一个算法来计算你所能获取的最大利润。你最多可以完成 两笔 交易。 注意&#xff1a;你不能同时参与多笔交易&#xff08;你必须在再次购买前出售掉之前的股票&#xff09;。 方法—动态…...

苍穹外卖问题记录(持续更新)

Day01_3.2.4前后端联调 1. 前端无法登录 &#xff08;1&#xff09;确保nginx服务器已经启动 &#xff08;2&#xff09;查看自己数据库的用户名和密码是否和老师的一样&#xff0c;不一样的话需要在application-dev.yml文件中把老师的用户名密码修改成自己的 老师的用户名…...

结合大象机器人六轴协作机械臂myCobot 280 ,解决特定的自动化任务和挑战!(下)

Limo Pro 小车建图导航 引言 前景提要&#xff1a;我们在上文介绍了使用LIMO cobot 实现一个能够执行复杂任务的复合机器人系统的应用场景的项目&#xff0c;从以下三个方面&#xff1a;概念设计、系统架构以及关键组件。 本文主要深入项目内核的主要部分&#xff0c;同样也主要…...

加速 Webpack 构建:提升效率的秘诀

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…...

Qt自定义标题栏的多屏适配

标题栏自定义 参考博客 &#xff1a; https://blog.csdn.net/goforwardtostep/article/details/53494800 多屏适配 MyTitleBar类抽象定义了自定义标题栏&#xff0c;使用起来相对方便。但是在多屏情况下&#xff0c;窗口初次显示只能在主屏幕上&#xff0c;如果拖到其他屏幕…...

【MySQL篇】 MySQL基础学习

文章目录 前言基础数据类型DDL数据库操作查询数据库创建数据库删除数据库使用数据库 DDL表操作创建表查询表修改表删除 DML-增删改添加数据更改数据删除数据 DQL-查询基础查询条件查询聚合函数分组查询排序查询分页查询编写顺序 DML-用户及权限用户管理权限控制 函数字符串函数…...

Qt多弹窗实现包括QDialog、QWidget、QMainWindow

1.相关说明 独立Widget窗口、嵌入式Widget、嵌入式MainWindow窗口、独立MainWindow窗口等弹窗的实现 相关界面包含关系 2.相关界面 3.相关代码 mainwindow.cpp #include "mainwindow.h" #include "ui_mainwindow.h" #include "tformdoc.h" #incl…...

Django高级之-forms组件

Django高级之-forms组件 1 校验字段功能 针对一个实例&#xff1a;注册用户讲解。 模型&#xff1a;models.py class UserInfo(models.Model):namemodels.CharField(max_length32)pwdmodels.CharField(max_length32)emailmodels.EmailField()模版文件 <!DOCTYPE html&g…...

GPT实战系列-LangChain实现简单链

GPT实战系列-LangChain实现简单链 LangChain GPT实战系列-LangChain如何构建基通义千问的多工具链 GPT实战系列-构建多参数的自定义LangChain工具 GPT实战系列-通过Basetool构建自定义LangChain工具方法 GPT实战系列-一种构建LangChain自定义Tool工具的简单方法 GPT实战系…...

关于tomcat服务器配置及性能优化的20道高级面试题

1. 请描述Tomcat服务器的基本架构和组件。 Tomcat服务器的基本架构主要包括Server、Service、Connector和Container等组件。具体来看&#xff1a; Server&#xff1a;是Tomcat中最顶层的容器&#xff0c;代表着整个服务器。它负责运行Tomcat服务器&#xff0c;例如打开和关闭…...

LeetCode 1315.祖父节点值为偶数的节点和

给你一棵二叉树&#xff0c;请你返回满足以下条件的所有节点的值之和&#xff1a; 该节点的祖父节点的值为偶数。&#xff08;一个节点的祖父节点是指该节点的父节点的父节点。&#xff09; 如果不存在祖父节点值为偶数的节点&#xff0c;那么返回 0 。 示例&#xff1a; 输入…...

C语言分支和循环总结

文章目录 概要结构介绍不同结构的语句简单运用小结 概要 C语言中分为三种结构&#xff1a;顺序结构&#xff0c;选择结构&#xff0c;循环结构 结构介绍 顺序结构就是从上到下&#xff0c;从左到右等等&#xff1b;选择结构可以想象是Y字路口就是到了一个地方会有不同的道路…...

【Echarts】曲线图上方显示数字以及自定义值,标题和副标题居中,鼠标上显示信息以及自定义信息

欢迎来到《小5讲堂》 大家好&#xff0c;我是全栈小5。 这是《前端》系列文章&#xff0c;每篇文章将以博主理解的角度展开讲解&#xff0c; 特别是针对知识点的概念进行叙说&#xff0c;大部分文章将会对这些概念进行实际例子验证&#xff0c;以此达到加深对知识点的理解和掌握…...

双环PID控制详细讲解

参考博客&#xff1a; &#xff08;1&#xff09;PID双环控制&#xff08;速度环和位置环&#xff09; &#xff08;2&#xff09;PID控制&#xff08;四&#xff09;&#xff08;单环与双环PID&#xff09; &#xff08;3&#xff09;内外双环pid算法 0 单环PID 目标位置→系…...

深入解析Java内存模型

一、背景 并发编程本质问题是&#xff1a;CPU、内存以及IO三者之间的速度差异。CPU速度快于内存、内存访问速度又远远快于IO&#xff0c;根据木桶理论&#xff0c;程序性能取决于最慢的操作&#xff0c;即IO操作。这样会出现CPU和内存交互时&#xff0c;CPU性能无法被充分利用…...

python使用国内镜像源

使用格式 格式为&#xff1a;pip install 库名 -i 镜像地址&#xff08;注意空格的存在&#xff09; pip install pandas -i https://pypi.tuna.tsinghua.edu.cn/simple 推荐的镜像源&#xff1a; 清华大学&#xff08;推荐&#xff09;&#xff1a;https://pypi.tuna.tsing…...

【动态规划】代码随想录算法训练营第四十六天 |139.单词拆分,关于多重背包,你该了解这些! ,背包问题总结篇!(待补充)

139.单词拆分 1、题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 2、文章讲解&#xff1a;代码随想录 3、题目&#xff1a; 给定一个非空字符串 s 和一个包含非空单词的列表 wordDict&#xff0c;判定 s 是否可以被空格拆分为一个或多个在字典中出现的单词…...

WordPress建站入门教程:如何选择和设置固定链接结构?

我们成功搭建好WordPress网站后&#xff0c;发布的文章对应的URL地址默认是使用“日期和名称型”&#xff0c;即是网站域名跟着的是年月日&#xff0c;最后是文章标题&#xff0c;如http://www.yigujin.com/2024/03/06/免费响应式WordPress博客主题JianYue/ 为了让我们的文章U…...

一款好用的AI工具——边界AICHAT(三)

目录 3.23、文档生成PPT演示3.24、AI文档翻译3.25、AI翻译3.26、论文模式3.27、文章批改3.28、文章纠正3.29、写作助手3.30、文言文翻译3.31、日报周报月报生成器3.32、OCR-DOC办公文档识别3.33、AI真人语音合成3.34、录音音频总结3.35、域方模型市场3.36、模型创建3.37、社区交…...

编程示例: 矩阵的多项式计算以javascript语言为例

编程示例: 矩阵的多项式计算以javascript语言为例 国防工业出版社的《矩阵理论》一书中第一章第8个习题 试计算2*A^8-3*A^5A^4A^2-4I A[[1,0,2],[0,-1,1],[0,1,0]] 代码如下 <html> <head> <title> 矩阵乘法 </title> <script srcset.js ><…...

Ammonite BSP协议详解:如何实现与IDE的无缝集成

Ammonite BSP协议详解&#xff1a;如何实现与IDE的无缝集成 【免费下载链接】Ammonite Scala Scripting 项目地址: https://gitcode.com/gh_mirrors/amm/Ammonite Ammonite作为一款强大的Scala脚本工具&#xff0c;通过BSP&#xff08;Build Server Protocol&#xff09…...

BeesAndroid实战教程:如何在Nexus 6设备上搭建Android 7.0开发环境

BeesAndroid实战教程&#xff1a;如何在Nexus 6设备上搭建Android 7.0开发环境 【免费下载链接】BeesAndroid 项目地址: https://gitcode.com/gh_mirrors/be/BeesAndroid BeesAndroid是一款专为Android开发者打造的开源项目&#xff0c;通过本教程&#xff0c;你将快速…...

避坑指南:处理通达信5分钟数据.lc5文件时你可能遇到的5个问题(Python解决方案)

避坑指南&#xff1a;处理通达信5分钟数据.lc5文件时你可能遇到的5个问题&#xff08;Python解决方案&#xff09; 在金融数据分析领域&#xff0c;通达信的.lc5文件是存储5分钟级别行情数据的重要格式。许多量化交易者和数据分析师在处理这类文件时&#xff0c;往往会遇到一些…...

C++ ostringstream实战指南:从基础到高级应用

1. 认识C中的ostringstream 第一次接触ostringstream时&#xff0c;我正面临一个棘手的问题&#xff1a;需要将各种数据类型混合输出到一个日志文件中。当时尝试了各种字符串拼接方法&#xff0c;不是性能低下就是代码难以维护。直到发现了ostringstream这个神器&#xff0c;才…...

OFA模型与微信小程序结合:打造个人相册智能描述工具

OFA模型与微信小程序结合&#xff1a;打造个人相册智能描述工具 每次翻看手机相册&#xff0c;面对成百上千张照片&#xff0c;你是不是也常常想不起来某张照片是在哪里拍的、当时发生了什么&#xff1f;或者想给一张特别有感觉的照片配上一段文字发朋友圈&#xff0c;却总是词…...

Milvus向量库内存暴涨:踩坑实录与解决思路

研一升研二&#xff0c;时间还相当充裕。你现在的方向很对&#xff0c;继续把项目做深做透&#xff0c;同时拓展一下搜推广的知识面&#xff0c;明年找实习问题不大。现在大部分公司的LLM业务岗&#xff0c;说白了&#xff0c;干的还是SFT和RAG那点事&#xff0c;顶多加个Agent…...

SEO 查看哪些页面最重要

SEO查看哪些页面最重要&#xff1a;深度解析与实用建议 在当今数字营销的世界中&#xff0c;搜索引擎优化&#xff08;SEO&#xff09;无疑是每个网站运营者都必须关注的关键环节。为了提升网站在搜索引擎结果中的排名&#xff0c;了解哪些页面对SEO最重要是至关重要的。本文将…...

像素时装锻造坊实战教程:用Enchantment功能将文字描述转为像素咒语技巧

像素时装锻造坊实战教程&#xff1a;用Enchantment功能将文字描述转为像素咒语技巧 1. 像素时装锻造坊简介 像素时装锻造坊是一款基于Stable Diffusion与Anything-v5的图像生成工具&#xff0c;它将AI图像生成与复古日系RPG游戏界面完美结合。不同于传统AI工具的单调界面&…...

QMCDecode:解锁QQ音乐加密格式,让音乐真正属于你

QMCDecode&#xff1a;解锁QQ音乐加密格式&#xff0c;让音乐真正属于你 【免费下载链接】QMCDecode QQ音乐QMC格式转换为普通格式(qmcflac转flac&#xff0c;qmc0,qmc3转mp3, mflac,mflac0等转flac)&#xff0c;仅支持macOS&#xff0c;可自动识别到QQ音乐下载目录&#xff0c…...

最通俗的 LDA 线性判别分析教程

&#x1f525; 最通俗的 LDA 线性判别分析教程&#xff08;本科生/研究生都能懂&#xff09; 大家好&#xff0c;今天我们来彻底吃透LDA&#xff08;线性判别分析&#xff09;。 这是机器学习、模式识别、数据降维里必考、必用、必懂的算法&#xff0c;面试、比赛、写论文都高频…...