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

代码随想录算法训练营|day48

第九章 动态规划

  • 121.买卖股票的最佳时机
  • 122.买卖股票的最佳时机II
  • 代码随想录文章详解

121.买卖股票的最佳时机

本题中股票只能买卖一次
dp[i][0] 表示第i天不买入股票持有的最大现金;dp[i][1] 表示第i天买入股票持有的最大现金。

不买股票持有的最大现金买入股票持有的最大现金
前一天为未买入状态     dp[i-1][0]
前一天为买入状态,今天卖出 dp[i-1][1]+prices[i]
前一天为买入状态 dp[i-1][1]
今天为买入状态  -prices[i]
func maxProfit(prices []int) int {if len(prices) == 0 {return 0}dp := make([][]int, len(prices))for i := 0; i < len(prices); i++ {dp[i] = make([]int, 2)}dp[0][0] = 0dp[0][1] = -prices[0]for i := 1; i < len(prices); i++ {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[len(prices) - 1][0]
}

空间优化:可以看到第i天状态只依赖于第i-1天的状态,因此只需要记录前一天状态即可

func maxProfit(prices []int) int {if len(prices) == 0 {return 0}dp0, dp1 := 0, -prices[0]for i := 1; i < len(prices); i++ {dp0 = max(dp0, dp1+prices[i])dp1 = max(dp1, -prices[i])}return dp0
}

贪心:在历史最低点买入,最高点卖出

func maxProfit(prices []int) int {if len(prices) == 0 {return 0}minPrice := prices[0]res := 0for i := 1; i < len(prices); i++ {if prices[i] < minPrice {minPrice = prices[i]}res = max(res, prices[i]-minPrice)}return res
}

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

较上题多了条件:股票可以进行多次买卖
dp[i][0] 表示第i天不买入股票持有的最大现金;dp[i][1] 表示第i天买入股票持有的最大现金。
所以在当天是买入状态时,持有的最大现金为前一天买入状态持有的最大现金前一天卖出今天买入后持有的最大现金的最大值

func maxProfit(prices []int) int {if len(prices) == 0 || len(prices) == 1 {return 0}dp := make([][]int, len(prices))for i := 0; i < len(prices); i++ {dp[i] = make([]int, 2)}dp[0][0] = 0dp[0][1] = -prices[0]for i := 1; i < len(prices); i++ {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]
}

空间优化

func maxProfit(prices []int) int {if len(prices) == 0 || len(prices) == 1 {return 0}dp0, dp1 := 0, -prices[0]for i := 0; i < len(prices); i++ {dp0 = max(dp0, dp1+prices[i])dp1 = max(dp1, dp0-prices[i])}return dp0
}

贪心:只加正数
因为不限制交易次数,故只要今天股价比昨天高,就交易。

func maxProfit(prices []int) int {if len(prices) == 0 || len(prices) == 1 {return 0}sum := 0for i := 1; i < len(prices); i++ {if prices[i] > prices[i-1] {sum += prices[i] - prices[i-1]}}return sum
}

代码随想录文章详解

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

http://www.lryc.cn/news/310215.html

相关文章:

  • 架构面试题汇总:并发和锁(三)
  • 蓝桥杯(3.2)
  • [数据集][目标检测]鸟类检测数据集VOC+YOLO格式11758张200类别
  • YOLOv9:使用可编程梯度信息学习您想学习的内容
  • uniapp:使用DCloud的uni-push推送消息通知(在线模式)java实现
  • 【简说八股】面试官:你知道什么是AOP么?
  • ASUS华硕天选5笔记本电脑FX607JV原装出厂Win11系统下载
  • Unity(第二十一部)动画的基础了解(感觉不了解其实也行)
  • 写时复制简介
  • 运行Python文件时出现‘utf-8’code can‘t decode byte 如何解决?(如图)
  • 行为树入门:BehaviorTree.CPP Groot2练习(叶子节点)(2)
  • leetcode-字符串中的单词数
  • 一些C语言题目
  • JVM相关问题
  • 32单片机基础:旋转编码器计次
  • 【C++】vector的使用和模拟实现(超级详解!!!!)
  • GO学习记录
  • 迭代器模式(Iterator Pattern)
  • KL divergence(KL 散度)详解
  • AzerothCore@FreeBSD安装记录
  • vue .env配置环境变量
  • ThreadLocal介绍
  • 【Linux系统化学习】线程概念
  • Redis集群模式
  • 执行go get xxx报错
  • MATLAB基础语法与实践
  • 智能边缘小站 CloudPond(低延迟、高带宽和更好的数据隐私保护)
  • 回归预测 | Matlab实现RIME-BP霜冰算法优化BP神经网络多变量回归预测
  • LeetCode15:三数之和
  • 【详识JAVA语言】面向对象程序三大特性之三:多态