刷题第四十二天 123. 买卖股票的最佳时机Ⅲ 188. 买卖股票的最佳时机Ⅳ

这篇具有很好参考价值的文章主要介绍了刷题第四十二天 123. 买卖股票的最佳时机Ⅲ 188. 买卖股票的最佳时机Ⅳ。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

刷题第四十二天 123. 买卖股票的最佳时机Ⅲ 188. 买卖股票的最佳时机Ⅳ,算法

class Solution:
    def maxProfit(self, prices: List[int]) -> int:
        # dp[i][0] 第i天第一次持有这只股票的最大现金
        # dp[i][1] 第i天第一次不持有这只股票的最大现金
        # dp[i][2] 第i天第二次持有
        # dp[i][3] 第i天第二次不持有

        # dp[i][0] = max(dp[i - 1][0], -prices[i])
        # 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 = [[0] * 4 for _ in range(len(prices))]
        dp[0][0] = -prices[0]
        dp[0][2] = -prices[0] #默认第一天第一次买入又卖出了
        for i in range(1,len(prices)):
            dp[i][0] = max(dp[i - 1][0], -prices[i])
            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])   
        return dp[-1][3]

和前一题的限制在于只能买卖两次,所以dp数组多定义一个状态,分别表示第一次持有 第一次不持有和第二次持有 第二次不持有,然后进行更新。

注意初始化的时候 第一次持有和第二次持有都需要默认0-prices[0]

刷题第四十二天 123. 买卖股票的最佳时机Ⅲ 188. 买卖股票的最佳时机Ⅳ,算法

class Solution:
    def maxProfit(self, k: int, prices: List[int]) -> int:
        # dp[i][k][0] 第i天第k + 1次持有
        # dp[i][k][1] 第i天第k + 1次不持有

        # k = 0
        # dp[i][k][0] = max(dp[i-1][k][0], - prices[i])
        # dp[i][k][1] = max(dp[i-1][k][1], dp[i - 1][k][0] + prices[i])
        # k != 0
        # dp[i][k][0] = max(dp[i-1][k][0], dp[i - 1][k - 1][1] - prices[i])
        # dp[i][k][1] = max(dp[i-1][k][1], dp[i - 1][k][0] + prices[i])

        dp = [[[0,0] for _ in range(k)] for _ in range(len(prices))]
        for i in range(k):
            dp[0][i][0] = -prices[0]
        for i in range(1, len(prices)):
            dp[i][0][0] = max(dp[i-1][0][0], - prices[i])
            dp[i][0][1] = max(dp[i-1][0][1], dp[i - 1][0][0] + prices[i])        
            for j in range(1, k):
                    dp[i][j][0] = max(dp[i-1][j][0], dp[i - 1][j - 1][1] - prices[i])
                    dp[i][j][1] = max(dp[i-1][j][1], dp[i - 1][j][0] + prices[i])               
        return dp[-1][-1][1]

和前一题的差别就是可以多次买卖,所以定义一个三维数组,表示每次持有和不持有文章来源地址https://www.toymoban.com/news/detail-752707.html

到了这里,关于刷题第四十二天 123. 买卖股票的最佳时机Ⅲ 188. 买卖股票的最佳时机Ⅳ的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

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

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

    2024年02月07日
    浏览(32)
  • 算法练习Day50|● 123.买卖股票的最佳时机III ● 188.买卖股票的最佳时机IV

    LeetCode:123.买卖股票的最佳时机III 123. 买卖股票的最佳时机 III - 力扣(LeetCode) 1.思路 将两次买入卖出转化为是否持有的状态,当天可进行两次买卖,故每天买卖有四种状态,四种状态包含了当天不买不卖的状态。 2.代码实现 3.复杂度分析 时间复杂度:O(n). 空间复杂度:O(1

    2024年02月12日
    浏览(33)
  • 算法训练第五十天 | 123.买卖股票的最佳时机III、188.买卖股票的最佳时机IV

    题目链接:123.买卖股票的最佳时机III 参考:https://programmercarl.com/0123.%E4%B9%B0%E5%8D%96%E8%82%A1%E7%A5%A8%E7%9A%84%E6%9C%80%E4%BD%B3%E6%97%B6%E6%9C%BAIII.html 视频讲解:https://www.bilibili.com/video/BV1WG411K7AR 给定一个数组,它的第 i 个元素是一支给定的股票在第 i 天的价格。 设计一个算法来计算你所

    2024年02月01日
    浏览(29)
  • java算法day50 | ● 123.买卖股票的最佳时机III ● 188.买卖股票的最佳时机IV

    思路: 这道题的关键就是如何设置dp数组的状态。用五种状态表示对股票持有或售出的不同阶段。代码随想录讲解视频 时间复杂度:O(n) 空间复杂度:O(n × 5) 思路: 在上一题2次的基础上变为k次。可以发现规律:除了0以外,偶数就是卖出,奇数就是买入。 因此dp数组的维度

    2024年04月11日
    浏览(32)
  • 力扣经典150题第七题:买卖股票最佳时机

    1. 简介 本篇博客将讨论力扣经典150题中的买卖股票的最佳时机问题。给定一个数组 prices ,其中第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格,我们需要设计一个算法来计算最大利润。 2. 问题描述 给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天

    2024年04月13日
    浏览(26)
  • 算法刷题|121.买卖股票的最佳时机、122.买卖股票的最佳时机Ⅱ

    题目:给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。 返回你可以从这笔交易中获取的最大利润。如果你不能获

    2023年04月26日
    浏览(29)
  • 算法刷题Day 51 最佳买卖股票时机含冷冻期+买卖股票的最佳时期含手续费

    关键是要画出状态转移图 然后根据状态转移图来写状态转移方程 这道题其实就是在买卖股票II的基础上加入一点变化而已,代码框架还是那个框架。

    2024年02月15日
    浏览(30)
  • 从零开始的力扣刷题记录-第四十二天

    题目描述: 给你长度相等的两个字符串 s1 和 s2 。一次 字符串交换 操作的步骤如下:选出某个字符串中的两个下标(不必不同),并交换这两个下标所对应的字符。 如果对 其中一个字符串 执行 最多一次字符串交换 就可以使两个字符串相等,返回 true ;否则,返回 false 。

    2024年02月06日
    浏览(42)
  • 代码随想录 第三十二天 45.跳跃游戏 II||122.买卖股票的最佳时机 II55. 跳跃游戏

    力扣题目链接(opens new window) 给定一个非负整数数组,你最初位于数组的第一个位置。 数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个位置。 示例  1: 输入: [2,3,1,1,4] 输出: true 解释: 我们可以先跳 1 步,从位置 0 到达 位置 1, 然后再从位

    2024年02月15日
    浏览(44)
  • leetcode刷题(轮转数组、买股票的最佳时机、买卖股票的最佳时机2、跳跃游戏、跳跃游戏2、最大子序列交替和、交替数字和、下降路径最小和)

    目录 1、轮转数组 2、买卖股票的最佳时机 3、买卖股票的最佳时机② 4、跳跃游戏 5、跳跃游戏2 6、最大子序列交替和 7、交替数字和 8、下降路径最小和 1、轮转数组 2、买卖股票的最佳时机 3、买卖股票的最佳时机② 4、跳跃游戏 5、跳跃游戏2 6、最大子序列交替和 7、交替数

    2024年02月16日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包