123.买卖股票的最佳时机III
视频讲解:动态规划,股票至多买卖两次,怎么求? | LeetCode:123.买卖股票最佳时机III_哔哩哔哩_bilibili
初步思路:买卖股票的最佳时机I。
总结:
关键在于至多买卖两次,这意味着可以买卖一次,可以买卖两次,也可以不买卖.
dpij中 i表示第i天,j为 0 - 4 五个状态,dpij表示第i天状态j所剩最大现金.
五个状态:
0: 没有操作; 1:第一次持有股票; 2:第一次不持有股票; 3:第二次持有股票; 4:第二次不持有股票
五个递推公式:
dpi0 = dpi-10
dpi1 = max(dpi-11, dpi-10 - pricesi)
dpi2 = max(dpi-12, dpi-11 + pricesi)
dpi3 = max(dpi-13, dpi-12 - pricesi)
dpi4 = max(dpi-14, dpi-13 + pricesi)
用时:60分钟
188.买卖股票的最佳时机IV
视频讲解:动态规划来决定最佳时机,至多可以买卖K次!| LeetCode:188.买卖股票最佳时机4_哔哩哔哩_bilibili
初步思路:买卖股票的最佳时机III。
dpij中 i表示第i天,j为 0 -- 2k 个状态,dpij表示第i天状态j所剩最大现金.
2k个状态:
0: 没有操作; 1:第一次持有股票; 2:第一次不持有股票; 3:第二次持有股票; 4:第二次不持有股票; ....
2k-1:第k次持有股票; 2k:第k次不持有股票;
2k个递推公式:
j is odd -> dpij = max(dpi - 1j, dpi - 1j-1 - pricesi)
j is even -> dpij = max(dpi - 1j, dpi - 1j-1 + pricesi)
用时:45分钟