day 43 | ● 123.买卖股票的最佳时机III ● 188.买卖股票的最佳时机IV

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

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

day 43 | ● 123.买卖股票的最佳时机III ● 188.买卖股票的最佳时机IV,数据结构与算法,算法,数据结构,leetcode
day 43 | ● 123.买卖股票的最佳时机III ● 188.买卖股票的最佳时机IV,数据结构与算法,算法,数据结构,leetcode

func maxProfit(prices []int) int {
    dp := make([][]int , len(prices))
    dp[0] = []int{0, -prices[0], 0, -prices[0], 0}

    for i := 1; i < len(prices);i++{
        val0 := dp[i - 1][0]
        val1 := max(dp[i - 1][0] - prices[i], dp[i - 1][1])
        val2 := max(dp[i - 1][1] + prices[i], dp[i - 1][2])
        val3 := max(dp[i - 1][2] - prices[i], dp[i - 1][3])
        val4 := max(dp[i - 1][3] + prices[i], dp[i - 1][4])
        dp[i] = []int{val0, val1, val2, val3, val4}
    }
    return dp[len(prices)- 1][4]
}
func max(a, b int)int{
    if a < b{
        return b
    }
    return a
}

● 188.买卖股票的最佳时机IV
和买卖股票3中的思路一样,只不过从两次换成了k次文章来源地址https://www.toymoban.com/news/detail-683767.html

func maxProfit(k int, prices []int) int {
    dp := make([][]int, len(prices))
    
    for i := 0; i < len(dp); i++{
        tmp := make([]int, 2 * k + 1)
        dp[i] = tmp
        if i == 0{
            for j := 1; j < 2 * k + 1; j += 2{
                dp[i][j] = -prices[0]
            }
        }
    }
    for i := 1; i < len(dp); i++{
        dp[i][0] = dp[i - 1][0]
        for j :=1; j < 2 * k + 1; j += 2{
            dp[i][j] = max(dp[i - 1][j - 1] - prices[i], dp[i - 1][j])
            dp[i][j + 1] = max(dp[i - 1][j] + prices[i], dp[i - 1][j + 1])
        }
    }
    return dp[len(prices) - 1][2 * k]
}
func max(a , b int)int{
    if a < b{
        return b
    }
    return a
}

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

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

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

相关文章

  • 力扣 188. 买卖股票的最佳时机 IV

    题目来源:https://leetcode.cn/problems/best-time-to-buy-and-sell-stock-iv/description/ C++题解:动态规划 思路同力扣 123. 买卖股票的最佳时机 III-CSDN博客,只是把最高2次换成k次。如果思路不清晰,可以将k从0写到4等找找规律。

    2024年02月20日
    浏览(38)
  • leetcode-188-买卖股票的最佳时机 IV

    https://leetcode.cn/problems/best-time-to-buy-and-sell-stock-iv/description/

    2024年02月10日
    浏览(41)
  • leetcode 188. 买卖股票的最佳时机 IV

            这道题是 买卖股票的最佳时机III  的升级版,即买卖次数限制为k次,做法和上一篇如法炮制,直接看代码:

    2024年02月12日
    浏览(37)
  • 刷题第四十二天 123. 买卖股票的最佳时机Ⅲ 188. 买卖股票的最佳时机Ⅳ

    和前一题的限制在于只能买卖两次,所以dp数组多定义一个状态,分别表示第一次持有 第一次不持有和第二次持有 第二次不持有,然后进行更新。 注意初始化的时候 第一次持有和第二次持有都需要默认0-prices[0] 和前一题的差别就是可以多次买卖,所以定义一个三维数组,表

    2024年02月05日
    浏览(47)
  • 动态规划-状态机(188. 买卖股票的最佳时机 IV)

    状态分类: f[i,j,0]考虑前i只股票,进行了j笔交易,目前未持有股票 所能获得最大利润 f[i,j,1]考虑前i只股票,进行了j笔交易,目前持有股票 所能获得最大利润 状态转移: f[i][j][0] = Math.max(f[i-1][j][0],f[i-1][j][1]+prices[i]); f[i][j][1] = Math.max(f[i-1][j][1],f[i-1][j-1][0]-prices[i]);   还有一位

    2024年02月08日
    浏览(44)
  • 123. 买卖股票的最佳时机 III

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

    2024年02月07日
    浏览(43)
  • 123.买卖股票的最佳时机II

    123.买卖股票的最佳时机II https://leetcode.cn/problems/best-time-to-buy-and-sell-stock-ii/description/

    2024年02月20日
    浏览(37)
  • 【学会动态规划】买卖股票的最佳时机 IV(18)

    目录 动态规划怎么学? 1. 题目解析 2. 算法原理 1. 状态表示 2. 状态转移方程 3. 初始化 4. 填表顺序 5. 返回值 3. 代码编写 写在最后: 学习一个算法没有捷径,更何况是学习动态规划, 跟我一起刷动态规划算法题,一起学会动态规划! 题目链接:188. 买卖股票的最佳时机 IV

    2024年02月13日
    浏览(43)
  • 【学会动态规划】买卖股票的最佳时机 III(17)

    目录 动态规划怎么学? 1. 题目解析 2. 算法原理 1. 状态表示 2. 状态转移方程 3. 初始化 4. 填表顺序 5. 返回值 3. 代码编写 写在最后: 学习一个算法没有捷径,更何况是学习动态规划, 跟我一起刷动态规划算法题,一起学会动态规划! 题目链接:123. 买卖股票的最佳时机 II

    2024年02月13日
    浏览(52)
  • 【Day53】代码随想录之动态规划part10——买卖股票的最佳时机、买卖股票的最佳时机II

    昨天已经把打家劫舍的问题解决了,最后一个题目涉及到树形dp比较难(等到二刷的时候再重点看下),今天的任务是解决股票问题。 今日任务: 121.买卖股票的最佳时机 122.买卖股票的最佳时机II Leetcode题目:【121.买卖股票的最佳时机】 因为此题中买卖股票只能买卖一次。

    2024年03月15日
    浏览(96)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包