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

【代码随想录训练营】【Day 49+】【动态规划-8】| Leetcode 121, 122, 123

【代码随想录训练营】【Day 49+】【动态规划-8】| Leetcode 121, 122, 123

需强化知识点

  • 买卖股票系列

题目

121. 买卖股票的最佳时机

  • 动态规划
  • 贪心:记录左侧的最小值
class Solution:def maxProfit(self, prices: List[int]) -> int:# n = len(prices)# # 0 代表 不持有,1 代表 持有# dp = [[0]*2 for _ in range(n)]# dp[0][1] = - prices[0] # for i in range(1, n):#     dp[i][0] = max(dp[i-1][0], dp[i-1][1]+prices[i])#     dp[i][1] = max(dp[i-1][1], -prices[i])# return dp[n-1][0]lowPrice = float('inf')result = 0 for i in range(0, len(prices)):lowPrice = min(lowPrice, prices[i])result = max(result, prices[i]-lowPrice)return result

122. 买卖股票的最佳时机 II

  • 注意 和 121的区别,在于第 i 天持有的时,dp[i-1][0]-prices[i] (121中默认dp[i-1][0]为0)
class Solution:def maxProfit(self, prices: List[int]) -> int:# 0 不持有, 1 持有dp = [[0]*2 for _ in range(len(prices))]dp[0][0] = 0dp[0][1] = -prices[0]for i in range(1, len(prices)):dp[i][0] = max(dp[i-1][0], dp[i-1][1]+prices[i])dp[i][1] = max(dp[i-1][1], dp[i-1][0]-prices[i])return dp[len(prices)-1][0]

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

  • 代码随想录思路:0-4 五种状态
class Solution:def maxProfit(self, prices: List[int]) -> int:# 0 没有操作# 1 第一次持有股票# 2 第一次不持有股票# 3 第二次持有股票# 4 第二次不持有股票n = len(prices)dp = [[0]*5 for _ in range(n)]dp[0][1], dp[0][3] = -prices[0], -prices[0]for i in range(1, n):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[n-1][4]
http://www.lryc.cn/news/372129.html

相关文章:

  • k8s metrics-server服务监控pod 的 cpu、内存
  • 电脑自带录屏在哪?电脑录屏,4个详细方法
  • [Cloud Networking] Layer3 (Continue)
  • missing authentication credentials for REST request
  • Unity 从0开始编写一个技能编辑器_02_Buff系统的生命周期
  • 计算机网络简答题
  • 探索Java 8 Stream API:现代数据处理的新纪元
  • vim 删除光标到最后一行的所有内容
  • k8s之kubelet证书时间过期升级
  • 5G消息 x 文旅 | 一站式智慧文旅解决方案
  • 如何评估员工在新版FMEA培训后应用知识的效果?
  • python脚本之解析命令参数
  • 当JS遇上NLP:开启图片分析的奇幻之旅
  • trpc快速上手
  • 知识图谱存在的挑战---隐私、安全和伦理相关和测试认证相关
  • 课时155:脚本发布_简单脚本_命令罗列
  • 借助ollama实现AI绘画提示词自由,操作简单只需一个节点!
  • PyTorch -- Visdom 快速实践
  • 基于xilinx FPGA的QSFP调试使用经验
  • WPF 使用Image控件显示图片
  • 合肥工业大学内容安全实验一:爬虫|爬新闻文本
  • 自动驾驶---Perception之视觉点云雷达点云
  • maven 显式依赖包包含隐式依赖包,引起依赖包冲突
  • Spring应用如何打印access日志和out日志(用于分析请求总共在服务耗费多长时间)
  • SpringBoot整合SpringDataRedis
  • 电脑怎么录制游戏视频?轻松捕捉每一帧精彩
  • 【Elasticsearch】索引快照并还原到其他集群
  • QT--DAY1
  • DSP教学实验箱_数字图像处理_操作教程:5-1 图像旋转
  • MyBatis总结(2)- MyBatis实现原理(三)