题目描述

给定一个数组,它的第 i 个元素是一支给定的股票在第 i 天的价格。

设计一个算法来计算你所能获取的最大利润。你最多可以完成 两笔 交易。

注意: 你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。

示例1

        输入:
[3,3,5,0,0,3,1,4]
输出:
6
解释:
在第 4 天(股票价格 = 0)的时候买入,在第 6 天(股票价格 = 3)的时候卖出,这笔交易所能获得利润 = 3-0 = 3 。
随后,在第 7 天(股票价格 = 1)的时候买入,在第 8 天 (股票价格 = 4)的时候卖出,这笔交易所能获得利润 = 4-1 = 3 。

示例2

        输入:
[1,2,3,4,5]
输出:
4
解释:
在第 1 天(股票价格 = 1)的时候买入,在第 5 天 (股票价格 = 5)的时候卖出, 这笔交易所能获得利润 = 5-1 = 4 。
注意你不能在第 1 天和第 2 天接连购买股票,之后再将它们卖出。
因为这样属于同时参与了多笔交易,你必须在再次购买前出售掉之前的股票。

示例3

        输入:
[7,6,4,3,1]
输出:
0
解释:
在这个情况下, 没有交易完成, 所以最大利润为 0。

题解

这是 【买卖股票的最佳时机】 系列题目的第三题。

本题中买卖次数变成了最多两次,那么我们可以照搬之前只能买卖一次的做法。首先如果我们假设第一只股票卖出去时价格是 ,那么它之前的最优买入价格(也就是最低的价格)计算方法和第一题相同,只需要用一个变量存储就行了。而第二次买卖我们只需要知道 右边进行一次买卖最多能赚到多少钱就行了。这可以通过从右向左倒过来预处理处理,方法和第一题完全相同。

记第 只股票左边(包含)买卖一次最大利润为 ,右边(包含)买卖一次最大利润为 ,那么最终的答案就是:

时间复杂度是

代码

python

        class Solution:def maxProfit(self, prices: List[int]) -> int:n = len(prices)if n == 0: return 0dp = [0] * nminn = prices[0]for i in range(1, n):dp[i] = max(dp[i-1], prices[i]-minn)minn = min(minn, prices[i])maxx, maxp, res = prices[-1], 0, max(dp)for i in range(n-2, 0, -1):maxp = max(maxp, maxx-prices[i])maxx = max(maxx, prices[i])res = max(res, dp[i-1]+maxp)return res

每日算法系列【LeetCode 123】买卖股票的最佳时机 III相关推荐

  1. LeetCode 123. 买卖股票的最佳时机 III(动态规划)

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

  2. leetcode 123. 买卖股票的最佳时机 III(dp)

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

  3. LeetCode 123. 买卖股票的最佳时机 III(Best Time to Buy and Sell Stock III)

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

  4. 107. Leetcode 123. 买卖股票的最佳时机 III (动态规划-股票交易)

    步骤一.确定状态: 确定dp数组及下标含义 dp[i] 表示的是在第i天可以获取的最大利润,每天会有持有股票和不持有股票两种状态,这个是 第二维度,还是用0和1表示. 而对于每一种状态,这里还会有交易 ...

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

    使用动态规划的解法,空间复杂度O(2*2)如果交易k次则为O(2*k),时间复杂度O(2n),交易k次为O(n*k), 因此本题实际上可以退化为买卖一次的情况:去掉buy2和sell2,即leetco ...

  6. 【贪心算法】Leetcode 714. 买卖股票的最佳时机含手续费

    [贪心算法]Leetcode 714. 买卖股票的最佳时机含手续费 题目 给定一个整数数组 prices,其中 prices[i]表示第 i 天的股票价格 :整数 fee 代表了交易股票的手续费用. ...

  7. 算法训练第五十天 | 123.买卖股票的最佳时机III、188.买卖股票的最佳时机IV

    动态规划part11 123.买卖股票的最佳时机III 题目描述 思路 拓展 188.买卖股票的最佳时机IV 题目描述 思路 易错点 123.买卖股票的最佳时机III 题目链接:123.买卖股票的最佳 ...

  8. 第43天| 123.买卖股票的最佳时机III、 188.买卖股票的最佳时机IV

    1.题目链接:123. 买卖股票的最佳时机 III 题目描述: 给定一个数组,它的第 i 个元素是一支给定的股票在第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你最多可以完成 两笔 交易 ...

  9. 123. 买卖股票的最佳时机 III ( 三维dp )

    LeetCode:123. 买卖股票的最佳时机 III 之前的含手续费定义了两个状态(持股与不持股), 含冷冻期定义了三个状态(持股, 不持股冷冻期, 不持股非冷冻期), 都是二维数组. 本题除了持股 ...

  10. 算法训练Day50 | LeetCode123. 买卖股票的最佳时机III(最多买卖2次);LeetCode188. 买卖股票的最佳时机IV(最多买卖K次)

    目录 LeetCode123. 买卖股票的最佳时机III 1. 思路 2. 代码实现 3. 复杂度分析 4. 思考与收获 LeetCode188. 买卖股票的最佳时机IV 1. 思路 2. 代码实现 ...

最新文章

  1. 【错误记录】Git 使用报错 ( no changes added to commit (use “git add“ and/or “git commit -a“) )
  2. mapping 详解1(mapping type)
  3. 无水印pdf编辑器_偷偷告诉你如何编辑PDF文件,轻松解决这万恶的千古难题
  4. Oracle级联查询
  5. Java作业09-异常
  6. VideoMemory, SystemMemory And AGPMemory
  7. 专题:CentOS社区企业操作系统
  8. Proteus 8.13 安装教程
  9. 移动通信原理、技术与系统——概述
  10. 嵌入式系统作业12(SD卡读取)
  11. 互联网公司纷纷裁员,大家都在说互联网行业进入了寒冬期,你怎么看待这个说法?
  12. 编辑中的word变成只读_word文件怎么将只读模式改为可以修改
  13. excel中为什么不显示单引号
  14. c#语言定义文档pdf,C#如何更改Word的语言设置.pdf
  15. 排序算法(一)——冒泡排序原理及Java实现
  16. STL和FIG文件的结构
  17. 解决手机连接不上电脑开的热点问题
  18. 初学C语言常见的错误
  19. 广数25i系统倒刀回刀m代码_基于广数GSK25i数控系统伺服刀库的控制
  20. vue+electron 跨平台桌面应用开发实战教程

热门文章

  1. 手动在viewpager的最后一页滑到第一页。
  2. Hadoop只输出Key不输出Value的小技巧‏
  3. 在Eclipse中使用JUnit4进行单元测试(上)
  4. CKFinder 2.0.2 破解小计
  5. java day18【线程池、Lambda表达式】
  6. centos安装python3.7和yum报错解决方法
  7. Part2-HttpClient官方教程-Chapter5-流利的API
  8. java系列1 环境变量配置
  9. UITextField-IOS开发
  10. Android的ALSA声卡