算法训练营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++ {

dpi = make(\[\]int, 2)

}

dp00 = -prices0

dp01 = 0

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

//买入后利润

dpi0 = max(dpi-10, -pricesi)

//不持有的利润

dpi1 = max(dpi-11, dpi-10+pricesi)

}

return dpn-11

}

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

func maxProfit2(prices \[\]int) int {

n := len(prices)

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

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

dpi = make(\[\]int, 2)

}

dp00 = -prices0

dp01 = 0

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

//买入后利润

dpi0 = max(dpi-10, dpi-11-pricesi)

//不持有的利润

dpi1 = max(dpi-11, dpi-10+pricesi)

}

return dpn-11

}

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

func maxProfit3(prices \[\]int) int {

n := len(prices)

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

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

dpi = make(\[\]int, 5)

}

dp01 = -prices0

dp03 = -prices0

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

//第一次买入后的利润

dpi1 = max(dpi-11, -pricesi)

//第一次不持有的利润

dpi2 = max(dpi-12, dpi-11+pricesi)

//第二次买入后的利润

dpi3 = max(dpi-13, dpi-12-pricesi)

//第二次不持有的利润

dpi4 = max(dpi-14, dpi-13+pricesi)

}

return dpn-14

}

相关推荐
唐青枫2 小时前
别再只会 if err != nil:Go error 从错误链到工程实战详解
go
小满zs16 小时前
Go语言第二章(小无相功)
后端·go
妙码生花16 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
老鹰86216 小时前
Google Wire 被官方抛弃,Uber Fx 启动就 panic,Go DI 还有救吗?
go
vibecoding日记17 小时前
双非如何快速入职字节等大厂大模型?真实案例分析:推理优化和投机解码
算法·求职·大模型工程师
yszaygr213819 小时前
Verilog参数化游程编码RLE模块
算法
望易20 小时前
刚设计的大模型架构-双域耦合认知框架
算法·架构
golang学习记1 天前
Go面试官:说说struct{}为什么占用0字节
go
复杂网络1 天前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法