算法打卡day44

今日任务:

1)309.最佳买卖股票时机含冷冻期

2)714.买卖股票的最佳时机含手续费

3)复习day19

309.最佳买卖股票时机含冷冻期

题目链接:309. 买卖股票的最佳时机含冷冻期 - 力扣(LeetCode)

给定一个整数数组,其中第 i 个元素代表了第 i 天的股票价格 。
设计一个算法计算出最大利润。在满足以下约束条件下,你可以尽可能地完成更多的交易(多次买卖一支股票):
你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。
卖出股票后,你无法在第二天买入股票 (即冷冻期为 1 天)。示例:
输入: [1,2,3,0,2]
输出: 3
解释: 对应的交易状态为: [买入, 卖出, 冷冻期, 买入, 卖出]

文章讲解:代码随想录 (programmercarl.com)

视频讲解:动态规划来决定最佳时机,这次有冷冻期!| LeetCode:309.买卖股票的最佳时机含冷冻期哔哩哔哩bilibili

思路:

这道题目是股票买卖问题的变种,引入了冷冻期的概念。

  1. 定义状态:在第 i 天,有三种可能的状态:
    • 持有股票(buy)
    • 不持有股票,且处于冷冻期(sold)
    • 不持有股票,且不处于冷冻期(no_cooldown)
  2. 使用动态规划来解决问题。定义三个数组 buy, sold, no_cooldown,分别表示在每一天结束时,处于对应状态下的最大利润。
  3. 初始化状态:
    • 第一天结束时,持有股票的最大利润为 -prices[0],其他状态的最大利润为 0。
  4. 状态转移:
    • 对于第 i 天,有以下状态转移:
      • 如果在第 i 天结束时持有股票(buy),则可能是在第 i-1 天就已经持有了股票(保持不变),或者是在第 i 天买入了股票(从 no_cooldown 状态转移而来):buy[i] = max(buy[i-1], no_cooldown[i-1] - prices[i])。
      • 如果在第 i 天结束时不持有股票且处于冷冻期(sell),则说明在第 i-1 天持有股票并且在第 i 天卖出了股票:sold[i] = buy[i-1] + prices[i]。
      • 如果在第 i 天结束时不持有股票且不处于冷冻期(cooldown),则说明在第 i-1 天处于冷冻期(sold):no_cooldown[i] = max(sold[i-1], cooldown[i-1])。
  5. 最终的最大利润为在最后一天结束时不持有股票(sold 或 no_cooldown)的最大值。
class Solution:def maxProfit(self, prices: List[int]) -> int:n = len(prices)if n < 2:return 0# 初始化状态数组buy = [-prices[0]] + [0] * (n - 1)  # 持有股票sold = [0] * n  # 不持有股票,且处于冷冻期no_cooldown = [0] * n  # 不持有股票,且不处于冷冻期# 状态转移for i in range(1,n):buy[i] = max(buy[i-1],no_cooldown[i-1]-prices[i])sold[i] = buy[i-1]+prices[i]no_cooldown[i] = max(sold[i-1],no_cooldown[i-1])# 返回最终结果return max(sold[-1],no_cooldown[-1])

714.买卖股票的最佳时机含手续费

题目链接:714. 买卖股票的最佳时机含手续费 - 力扣(LeetCode)

给定一个整数数组 prices,其中第 i 个元素代表了第 i 天的股票价格 ;非负整数 fee 代表了交易股票的手续费用。
你可以无限次地完成交易,但是你每笔交易都需要付手续费。如果你已经购买了一个股票,在卖出它之前你就不能再继续购买股票了。
返回获得利润的最大值。
注意:这里的一笔交易指买入持有并卖出股票的整个过程,每笔交易你只需要为支付一次手续费。示例 1:
输入: prices = [1, 3, 2, 8, 4, 9], fee = 2
输出: 8
解释: 能够达到的最大利润
在此处买入 prices[0] = 1
在此处卖出 prices[3] = 8
在此处买入 prices[4] = 4
在此处卖出 prices[5] = 9
总利润: ((8 - 1) - 2) + ((9 - 4) - 2) = 8.注意:
0 < prices.length <= 50000.
0 < prices[i] < 50000.
0 <= fee < 50000.

文章讲解:代码随想录 (programmercarl.com)

视频讲解:动态规划来决定最佳时机,这次含手续费!| LeetCode:714.买卖股票的最佳时机含手续费哔哩哔哩bilibili

思路:

这个问题可以使用动态规划来解决。我们可以维护两个状态数组:hold和no_hold

,分别表示持有股票和现金的状态下的最大利润。

具体的动态规划转移方程如下:

  • 对于hold[i],表示第 i 天持有股票时的最大利润。可以由以下两种状态转移得到:
    • 在第 i 天买入股票(从前一天的现金状态转移而来):hold[i] = max(hold[i-1], no_hold[i-1] - prices[i])。
    • 第 i 天不进行任何操作(保持持有股票状态):hold[i] = hold[i-1]。
  • 对于no_hold[i],表示第 i 天不持有股票时的最大利润。可以由以下两种状态转移得到:
    • 在第 i 天卖出股票(从前一天持有股票状态转移而来):no_hold[i] = max(cash[i-1], hold[i-1] + prices[i] - fee)。
    • 第 i 天不进行任何操作(保持现金状态):no_hold[i] = no_hold[i-1]。

最终的答案就是no_hold[n-1],其中 n 是股票价格数组的长度。

这里为了方便理解,采用数组维护两个变量

代码中我们可以直接采用数维护两个变量

class Solution:def maxProfit(self, prices: List[int], fee: int) -> int:n = len(prices)if n < 2:return 0# 定义状态变量hold = -prices[0]  # 持有股票时的最大利润no_hold = 0  # 不持有股票时的最大利润# 遍历股票价格数组for price in prices[1:]:# 计算持有股票的状态hold = max(hold,no_hold-price)# 计算不持有股票的状态no_hold = max(no_hold,hold+price-fee)return no_hold

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

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

相关文章

快来看 2024年ICLR杰出论文奖揭晓啦 值得关注

会议之眼 快讯 在人工智能的浪潮中&#xff0c;国际学习表征会议&#xff08;ICLR&#xff09;无疑是引领学术前沿的重要会议之一&#xff01;ICLR是深度学习领域的顶级会议之一&#xff0c;由深度学习领域的两位巨头Yoshua Bengio和Yann LeCun于2013年创办。 2024年5月6日&a…

NSSCTF中的web

目录 [第五空间 2021]WebFTP [LitCTF 2023]PHP是世界上最好的语言&#xff01;&#xff01; [SWPUCTF 2021 新生赛]PseudoProtocols [LitCTF 2023]导弹迷踪 [NISACTF 2022]easyssrf [第五空间 2021]WebFTP 1.进入页面&#xff0c;发现是登录页面&#xff0c;想到 弱口令&…

反射技术介绍以及底层逻辑使用

反射概述&#xff1a; 1.反射是指对于任何一个Class类&#xff0c;在"运行的时候"都可以直接得到这个类全部成分。 2.在运行时,可以直接得到这个类的构造器对象&#xff1a;Constructor 3.在运行时,可以直接得到这个类的成员变量对象&#xff1a;Field 4.在运行时,可…

大模型微调之 在亚马逊AWS上实战LlaMA案例(六)

大模型微调之 在亚马逊AWS上实战LlaMA案例&#xff08;六&#xff09; 通过 SageMaker Python SDK 进行微调Llama2 可以使用 SageMaker Python SDK 微调 Llama 2 模型。以下是在数据集上微调 Llama 2 7B 的示例代码&#xff1a; import os import boto3 from sagemaker.sessi…

【RAG 博客】Small-to-Big Retrieval

Blog&#xff1a;Advanced RAG 01: Small-to-Big Retrieval ⭐⭐⭐⭐ Code&#xff1a;https://colab.research.google.com/github/sophiamyang/demos/blob/main/advanced_rag_small_to_big.ipynb Small-to-Big Retrieval 技术试图解决这样一个矛盾&#xff1a;更大的 chunk 可…

28 JavaScript学习: 代码规范

代码规范通常包括以下几个方面: 变量和函数的命名规则空格&#xff0c;缩进&#xff0c;注释的使用规则。其他常用规范…… 变量名 在编写JavaScript代码时&#xff0c;遵守良好的变量命名规范是非常重要的&#xff0c;这可以增加代码的可读性和可维护性。以下是一些常见的…

iOS ------ 内存五大分区

1&#xff0c;内存的概念&#xff1a; 虚拟内存&#xff08;Virtual Memory&#xff09;&#xff1a;虚拟内存是操作系统提供的一种机制&#xff0c;它使得应用程序能够访问超出物理内存限制的内存空间。虚拟内存将应用程序的内存地址空间分割成固定大小的页面&#xff08;Pag…

18.Docker学习

1.Docker应用场景 Docker借鉴了标准集装箱的概念。标准集装箱将货物运往世界各地&#xff0c;Docker&#xff08;模板&#xff09;将软件运往各个环境&#xff08;测试环境和生产环境拉取镜像&#xff08;实例&#xff09;&#xff09;&#xff0c;相当于是一个模子刻出来的 …

路由策略与路由控制

1.路由控制工具 匹配工具1&#xff1a;访问控制列表 &#xff08;1&#xff09;通配符 当进行IP地址匹配的时候&#xff0c;后面会跟着32位掩码位&#xff0c;这32位称为通配符。 通配符&#xff0c;也是点分十进制格式&#xff0c;换算成二进制后&#xff0c;“0”表示“匹配…

【软考】模拟考卷错题本2024-05-07

1 项目路径 这里的图没有加载出来&#xff0c;没u哦i关系了。其实主要是的算出最长的路径中包含那些元素即可。这里是蒙圈了&#xff0c;没有考虑到还有更长的。要顾头也顾尾。 2 算法分析-贪心 该问题主要考核的是算法设计策略来达到目标的方式。主要的设计策略有&#xff1a;…

Linux变量的认识及环境变量配置详解

文章目录 1、变量的划分2、局部变量3、全局变量4、环境变量4.1、概述4.2、配置临时环境变量4.3、配置永久环境变量4.3.1、用户级配置文件1&#xff09;配置方法一&#xff1a;~/.bashrc文件2&#xff09;配置方法二&#xff1a;~/.profile文件3&#xff09;配置方法三&#xff…

CTF-reverse二维四向迷宫路径求解

二维四向迷宫是一个re中的常考点&#xff0c;说不上难&#xff0c;但也不简单&#xff0c;本篇记录了常规的二维四向迷宫解题套路以及帮助快速解题的脚本 可能你看我的教程会觉得十分繁琐&#xff0c;但实际只要你用了一次熟练之后&#xff0c;基本都是拿到迷宫就一题一分钟解决…

c++实现数据库连接池

介绍 为提高mysql的访问性能&#xff0c;可增加连接池。为什么他能提高性能&#xff1a; mysql是基于C/S架构&#xff0c;从客户端到服务器&#xff0c;一条sql的执行流程&#xff1a;tcp三次握手->mysql连接认证->执行sql->关闭mysql连接->tcp四次挥手 每次数据库…

jmeter控制器讲解

1&#xff0c;随机顺序控制器和随机控制器的区别&#xff1a;随机顺序控制器下所有的接口都会执行&#xff0c;只是执行顺序是随机的&#xff0c;随机控制器下所有的接口中随机执行一个接口&#xff0c;其余接口不执行。

【跨境商家必读】TikTok Shop商城运营全指南

随着社交媒体和电子商务之间界限的日益模糊&#xff0c;一种全新的购物平台——TikTok商城&#xff0c;正在迅速成为全球跨境商家们关注的焦点。在这个竞争激烈的TikTok跨境电商领域中&#xff0c;了解如何有效利用TikTok Shop的各项功能&#xff0c;理解其独特的运营模式&…

Linux进程——Linux进程间切换与命令行参数

前言&#xff1a;在上一篇了解完进程状态后&#xff0c;我们简单了解了进程优先级&#xff0c;然后遗留了一点内容&#xff0c;本篇我们就来研究进程间的切换&#xff0c;来理解上篇提到的并发。如果对进程优先级还有没理解的地方可以先阅读&#xff1a; Linux进程优先级 本篇…

Gmail邮箱怎么注册?2024年完整指南(包含跳过手机号验证)

一、为什么要注册Gmail邮箱&#xff1f; 全球通用性&#xff1a;Gmail是一个全球性的邮件服务平台&#xff0c;被广泛认可和信赖。因为客户对于Gmail的接受度高&#xff0c;无需担心邮件被自动标记为垃圾邮件。 整合营销工具&#xff1a;通过Gmail账号&#xff0c;你可以轻松…

拼接图片路径不显示:vue

下面这2中方法都不能显示图片 <img :src"/assets/ scope.row.iconName.svg" width"15"/> <img :src"/assets/icons/${scope.row.iconName}.svg" width"15"/> 而这样可以 <img src"/assets/icons/sign.svg" …

C++之大数运算

溪云初起日沉阁 山雨欲来风满楼 契子✨ 我们知道数据类型皆有范围&#xff0c;一旦超出了这个范围就会造成溢出问题 今天说说我们常见的数据类型范围&#xff1a; 我们平时写代码也会遇到数据类型范围溢出问题&#xff1a; 比如 ~ 我们之前写的学生管理系统在用 int类型 填写…

stack的使用

1.栈的定义 我们可以看到模板参数里面有一个容器适配器 &#xff0c;什么是适配器&#xff1f;比如充电器就叫做电源适配器&#xff0c;用在做转换&#xff0c;对电压进行相关的转换适配我们的设备。栈&#xff0c;队列不是自己直接管理数据&#xff0c;是让其他容器管理数据&a…