【LeetCode75】第六十五题买卖股票的最佳时机含手续费

news2025/1/11 10:14:17

目录

题目:

示例:

分析:

代码:


题目:

示例:

分析:

这是力扣里动态规划类题目里的一道系列题目,买卖股票,直接在题库里搜就能搜到这一系列。

 我建议各位可以先去做一下这系列的其他题目,至少是吧买卖股票的最佳时机1和2做一下。

那么接下来我们来分析分析这道题怎么做。

首先是给一个数组,第 i 个数表示第 i 天的股票价格,我们如果没有股票就可以按照这个价格买入。如果我们手上有股票,就可以按照这个价格卖出,不过卖出的时候需要扣除一笔手续费。

问我们最多能获利多少。

那么我们直接用动态规划来做。

首先我们需要先定义好dp数组的含义。这个先放一边。

我们来分析一下,在本题中,我们的状态是持有股票和没有持有股票两种状态。

而我第 i 天持有股票时能拥有的最多收益是我第 i - 1天持有股票时能拥有的最多收益或者是我第 i - 1天没有持有股票时的最多收益再扣除第 i 天的股票价格,因为我第 i - 1 天没有股票的话,我在第 i 天有股票那就只能是在第 i 天买入股票。

在这两种情况下我们选一个最大值作为我们第 i 天持有股票时能拥有的最多收益。

而我第 i 天没有股票时能拥有的最多收益则是我第 i - 1 天没有股票的最多收益或者是我第 i - 1 天持有股票时拥有的最多收益再加上第 i 天的股票价格再扣除手续费。

在这两种情况下我们选一个最大值作为我们第 i 天没有股票时拥有的最多收益。

这就是我们的递推公式。

由于我们只有两种状态需要保存,因此dp数组的大小为2*n,n是股票价格数组的长度。

我们规定dp[ 0 ][ i ]存放的是第 i 天持有股票时拥有的最多收益。

规定dp[ 1 ][ i ]存放的是第 i 天没有股票时拥有的最多收益。

递推公式就是这样:

 接下来的问题就是初始化。由于我们的递推公式里有 i - 1 的操作,因此 i 至少等于1,等于0就会下标越界。所以我们需要初始化的是dp[ 0 ][ 0 ]和dp[ 1 ][ 0 ]

dp[ 0 ][ 0 ]的含义就是在第0天我持有股票时拥有的最多利润,那么第0天我要持有股票,那么只能是在第0天就买了股票,所以dp[ 0 ][ 0 ]初始化成负的第0天的股票价格。

而dp[ 1 ][ 0 ]的含义就是在第0天我不持有股票时拥有的最多利润,直接为0即可。

接下来我们用递推公式填满dp数组,最后返回dp[ 1 ][ n - 1 ],n为股票价格数组的长度。

为什么是dp[ 1 ][ n - 1 ]而不是dp[ 0 ][ n - 1 ],因为我都到最后一天了,手里有没有股票我后面都卖不掉了,所以自然是手上的股票都抛完了的情况下我的利润最大。

代码:

class Solution {
public:
    int maxProfit(vector<int>& prices, int fee) {
        vector<vector<int>>dp(2,vector<int>(prices.size()));
        //dp[0]持有股票,dp[1]不持有股票
        dp[0][0]=-prices[0];
        for(int i=1;i<prices.size();i++){
            dp[0][i]=max(dp[0][i-1],dp[1][i-1]-prices[i]);
            dp[1][i]=max(dp[1][i-1],dp[0][i-1]+prices[i]-fee);
        }
        return dp[1][prices.size()-1];
    }
};

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

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

相关文章

经验分享|甘肃某中型灌区信息化管理平台案例

河西走廊绿洲灌区&#xff0c;润泽万亩良田 甘肃某中型灌区位于河西走廊中端的黑河中游&#xff0c;从黑河引水自流灌溉&#xff0c;通过渠首输配水闸站&#xff0c;将水量输送并分配到田间&#xff0c;进行灌溉。 该灌区所处区域是农业灌溉大县&#xff0c;是甘肃河西走廊…

编程新时代:Amazon CodeWhisperer 助您轻松驾驭代码世界

文章目录 一、什么是 Amazon CodeWhisperer&#xff1f;二、个人无限免费使用三、安装配置3.1 手把手教你在pycharm配置3.2 同理在VSCODE安装 三、Pycharm上测试3.1 根据注释写代码3.2 检查修复代码错误3.3 构建一个简单爬虫 四、 VSCODE上测试4.1 个性化体验4.2 系统兼容性4.3…

项目任务管理上的一些总结

1. 开发任务管理现状&#xff1a; 1&#xff1a;基于禅道进行任务派发&#xff0c;缺少任务统计&#xff0c;进度上只能以“来不及”、“进度正常”、“进度延后”等模糊字眼。 2&#xff1a;“感觉”工作效率不高了&#xff0c;工作量是否饱和&#xff0c;任务投入产出偏差多…

桥梁模板人工费多少钱?

桥梁模板是桥梁工程中不可或缺的一部分&#xff0c;它起到支撑和固定混凝土浇筑的作用。在桥梁建设中&#xff0c;模板人工费用是一个重要的成本因素。那么&#xff0c;桥梁模板人工费到底是多少呢&#xff1f;下面我们来详细了解一下。 首先&#xff0c;需要明确的是&#xff…

目标检测算法改进系列之Backbone替换为EMO

EMO&#xff1a;结合 Attention 重新思考移动端小模型中的基本模块 近年来&#xff0c;由于存储和计算资源的限制&#xff0c;移动应用的需求不断增加&#xff0c;因此&#xff0c;本文的研究对象是端侧轻量级小模型 (参数量一般在 10M 以下)。在众多小模型的设计中&#xff0…

安防监控/视频监控系统EasyCVR平台界面侧边栏优化

视频汇聚/视频云存储/集中存储/视频监控管理平台EasyCVR能在复杂的网络环境中&#xff0c;将分散的各类视频资源进行统一汇聚、整合、集中管理&#xff0c;实现视频资源的鉴权管理、按需调阅、全网分发、云存储、智能分析等&#xff0c;视频智能分析平台EasyCVR融合性强、开放度…

windows10系统镜像安装含驱动补丁

前言 都2023年了为什么不装windows11, 当然是硬件不支持了(TPM), 当然你也可以跳过TPM验证硬装 Windows11对系统的要求 如何检测TPM :WindowsR, 输入 tpm.msc 检测是否兼容TMP 言归正传,开始安装 windows10镜像下载 windows11镜像下载 下载工具按流程安装即可 驱动补丁安装…

【SpringCloud】-Ribbon负载均衡

一、背景介绍 项目中使用到的SpringCloud Alibaba这一套微服务架构中服务注册与发现Nacos兼容了Feign&#xff0c;而Feign默认集成了Ribbon&#xff0c;当Nacos下使用Feign默认实现了负载均衡的效果。即使是默认集成了&#xff0c;也要追根溯源。 二、过程 负载均衡是什么&am…

00后卷王的自述,我真的很卷吗?

前言 前段时间去面试了一个公司&#xff0c;成功拿到了offer&#xff0c;薪资也从12k涨到了18k&#xff0c;对于工作都还没两年的我来说&#xff0c;还是比较满意的&#xff0c;毕竟一些工作3、4年的可能还没我高。 我可能就是大家说的卷王&#xff0c;感觉自己年轻&#xff…

设计模式2、抽象工厂模式 Abstract Factory

解释说明&#xff1a;提供一个创建一系列相关或相互依赖对象的接口&#xff0c;而无需指定他们具体的类。 简言之&#xff0c;一个工厂可以提供创建多种相关产品的接口&#xff0c;而无需像工厂方法一样&#xff0c;为每一个产品都提供一个具体工厂 抽象工厂&#xff08;Abstra…

【2251. 花期内花的数目】

来源&#xff1a;力扣&#xff08;LeetCode&#xff09; 描述&#xff1a; 给你一个下标从 0 开始的二维整数数组 flowers &#xff0c;其中 flowers[i] [starti, endi] 表示第 i 朵花的 花期 从 starti 到 endi &#xff08;都 包含&#xff09;。同时给你一个下标从 0 开始…

jeecgboot-3.5.5本地安装部署

一、开发环境说明 1、jdk1.8&#xff1a;java运行环境 2、Maven&#xff1a;项目依赖管理 3、git&#xff1a;代码管理 4、mysql5.7:数据管理。也可以是orcale、pgsql等 华为云HECS云服务器docker环境下安装mysql_supersolon的博客-CSDN博客 5、redis&#xff1a;缓存管理…

Goby 漏洞发布|Cockpit 平台 upload 文件上传漏洞(CVE-2023-1313)

漏洞名称&#xff1a;Cockpit 平台 upload 文件上传漏洞&#xff08;CVE-2023-1313&#xff09; English Name&#xff1a; Cockpit File Upload Vulnerability(CVE-2023-1313) CVSS core:7.2 影响资产数&#xff1a;3185 漏洞描述&#xff1a; Cockpit 是一个自托管、灵活…

[C++ 网络协议] 重叠I/O模型

目录 1. 什么是重叠I/O模型 2. 重叠I/O模型的实现 2.1 创建重叠非阻塞I/O模式的套接字 2.2 执行重叠I/O的Send函数 2.3 执行重叠I/O的Recv函数 2.4 获取执行I/O重叠的函数的执行结果 2.5 重叠I/O的I/O完成确认 2.5.1 使用事件对象&#xff08;使用重叠I/O函数的第六个参…

【x265 源码分析系列】:概述

介绍 x265 也属于 VLC 的 project。 版本&#xff1a; x265-3.5&#xff08;TAG-208&#xff09; git&#xff1a; https://bitbucket.org/multicoreware/x265_git.git 编码特点&#xff1a; 研究了一段时间的 HEVC 编码标准&#xff0c;最近开始研究符合 HEVC 标准的开源…

STM32G070RBT6-MCU温度测量(ADC)

1、借助STM32CubeMX生成系统及外设相关初始化代码。 在以上配置后就可以生成相关初始化代码了。 /* ADC1 init function */ void MX_ADC1_Init(void) {/* USER CODE BEGIN ADC1_Init 0 *//* USER CODE END ADC1_Init 0 */ADC_ChannelConfTypeDef sConfig {0};/* USER COD…

MyBatis-Plus通用Service快速实现赠三改查[MyBatis-Plus系列] - 第489篇

历史文章&#xff08;文章累计480&#xff09; 《国内最全的Spring Boot系列之一》 《国内最全的Spring Boot系列之二》 《国内最全的Spring Boot系列之三》 《国内最全的Spring Boot系列之四》 《国内最全的Spring Boot系列之五》 《国内最全的Spring Boot系列之六》 M…

综述 | 关于点云配准的全面综述(二)

原创 | 文 BFT机器人 05 基于优化的配准方法 基于优化的方法的关键思想是开发复杂的优化策略来实现方程&#xff08;1&#xff09;中非线性问题的最优解。 由于同源挑战的影响&#xff0c;这个非线性问题变得具有挑战性。图&#xff08;2a&#xff09;总结了该类别的主要过程。…

从零开始之了解电机及其控制(11)实现空间矢量调制

广泛地说&#xff0c;空间矢量调制只是将电压矢量以及磁场矢量在空间中调制到任意角度&#xff0c;通常同时最大限度地利用整个电压范围。 其他空间矢量调制模式确实存在&#xff0c;并且根据您最关心的内容&#xff0c;它们可能值得研究。 如何实际执行这种所谓的交替反向序列…

看看属猴人性格及近几年的运势怎么样?

属猴的人五行主金&#xff0c;乃是申金之所在&#xff0c;金旺之人&#xff0c;外显懒散&#xff0c;内心富有主见&#xff0c;行事坚定&#xff0c; 有贯彻始终之斗志&#xff0c;与他人合作融洽&#xff0c;且得以财运颇多&#xff1b; 主金&#xff0c;杀伐果决、精明干练&a…