算法训练营day42(补),动态规划10

func max(a, b int) int {

if a > b {

return a

}

return b

}

//121. 买卖股票的最佳时机

func maxProfit1(prices []int) int {

n := len(prices)

dp := make([][]int, n)

for i := 0; i < n; i++ {

dp[i] = make([]int, 2)

}

dp[0][0] = -prices[0]

dp[0][1] = 0

for i := 1; i < n; 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])

}

return dp[n-1][1]

}

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

func maxProfit2(prices []int) int {

n := len(prices)

dp := make([][]int, n)

for i := 0; i < n; i++ {

dp[i] = make([]int, 2)

}

dp[0][0] = -prices[0]

dp[0][1] = 0

for i := 1; i < n; 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[n-1][1]

}

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

func maxProfit3(prices []int) int {

n := len(prices)

dp := make([][]int, n)

for i := 0; i < n; i++ {

dp[i] = make([]int, 5)

}

dp[0][1] = -prices[0]

dp[0][3] = -prices[0]

for i := 1; i < n; i++ {

//第一次买入后的利润

dp[i][1] = max(dp[i-1][1], -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]

}

相关推荐
YuTaoShao9 分钟前
【LeetCode 每日一题】1458. 两个子序列的最大点积——(解法三)状态压缩
算法·leetcode·职场和发展
位东风17 分钟前
希尔排序(Shell Sort)详解
算法·排序算法
AI科技星31 分钟前
光速飞行器动力学方程的第一性原理推导、验证与范式革命
数据结构·人工智能·线性代数·算法·机器学习·概率论
橘颂TA33 分钟前
【剑斩OFFER】算法的暴力美学——leetCode 946 题:验证栈序列
c++·算法·leetcode·职场和发展·结构与算法
闻缺陷则喜何志丹35 分钟前
【状态机动态规划】3686. 稳定子序列的数量|1969
c++·算法·动态规划·力扣·状态机动态规划
寻星探路1 小时前
【算法通关】双指针技巧深度解析:从基础到巅峰(Java 最优解)
java·开发语言·人工智能·python·算法·ai·指针
wen__xvn1 小时前
力扣第 484 场周赛
算法·leetcode·职场和发展
YuTaoShao1 小时前
【LeetCode 每日一题】865. 具有所有最深节点的最小子树——(解法一)自顶向下
算法·leetcode·职场和发展
寻星探路1 小时前
【算法专题】哈希表:从“两数之和”到“最长连续序列”的深度解析
java·数据结构·人工智能·python·算法·ai·散列表