買股票的最佳時機(一次買入一次賣出,兩次,多次)
一次買入和一次賣出的情況
解法一:
class Solution:
def maxProfit(self, prices: List[int]) -> int:
miniprice = float('inf')
maxprofit = 0
for price in prices:
miniprice = min(miniprice, price)
maxprofit = max(maxprofit, price-miniprice)
return maxprofit
解法二:
dp[i]表示第i天最大收益dp[i] = max(dp[i-1], price[i] - miniprice)
class Solution:
def maxProfit(self, prices: List[int]) -> int:
if not prices:
return 0
else:
dp = [0 for _ in range(len(prices))]
miniprice = prices[0]
for i in range(1, len(prices)):
miniprice = min(miniprice, prices[i])
dp[i] = max(dp[i-1], prices[i]-miniprice)
return dp[-1]
兩次買入賣出的情況
class Solution:
def maxProfit(self, prices: List[int]) -> int:
if not prices:
return 0
dp = [0 for _ in range(5)]
dp[0] = 0
dp[1] = -prices[0]
dp[2] = float('-inf')
dp[3] = -prices[0]
dp[4] = float('-inf')
for i in range(len(prices)):
# 如果價格比昨天低就更新第一次買入的價格
dp[1] = max(dp[1], dp[0]-prices[i])
# 如果賣出價格比昨天賣出的價格高就更新
dp[2] = max(dp[2], dp[1]+prices[i])
# 同第一次的操作,不過這時候已經有第一次買賣的收入
dp[3] = max(dp[3], dp[2]-prices[i])
dp[4] = max(dp[4], dp[3]+prices[i])
return max(dp)
兩次買賣的話拆分成5種狀態:
dp[0] 沒有進行買賣
dp[1] 第一次買入
dp[2] 第一次賣出
dp[3] 第二次買入
dp[4] 第二次賣出
我覺得問題的關鍵在於,第一次和第二買賣不會進行交叉,所以第一次買了之後只能賣了才進行下一次買賣,這樣問題的狀態拆分就很簡單了。動態規劃解法的話需要初始狀態和狀態公式。
初始狀態:假設當天買或者不買,dp[0]顯然是0,dp[2]和dp[4]顯然還沒賣出是沒有收益的,dp[1]和dp[3]買入肯定是扣除當天的價格的。
總的來說配合程式碼不難理解,思路是dp[i]
代表當前狀態的收益。
不限次數買入賣出
題目改成這樣之後又變得簡單了。自行腦補一個月k線,題目的意思是我們可以馬後炮,知道走勢的情況下,如何做到最大收益——就是把所有上升的曲線都買了。
大佬講的實在太好了。忍不住引用
作者:jyd
連結:https://leetcode-cn.com/problems/best-time-to-buy-and-sell-stock-ii/solution/best-time-to-buy-and-sell-stock-ii-zhuan-hua-fa-ji/ 來源:力扣(LeetCode) 著作權歸作者所有。商業轉載請聯絡作者獲得授權,非商業轉載請註明出處。
class Solution:
def maxProfit(self, prices: List[int]) -> int:
if not prices:
return 0
profit = 0
for i in range(1,len(prices)):
tmp = prices[i] - prices[i-1]
if tmp>0:
profit += tmp
return profit
相關文章
- 買賣股票的最佳時機 II
- Leetcode121、買賣股票的最佳時機(Python題解)只買一次,位元組跳動面試題LeetCodePython面試題
- leetcode 121 買賣股票的最佳時機LeetCode
- 122 買賣股票的最佳時機 II
- 121. 買賣股票的最佳時機
- 買賣股票的最佳時機 IV javaJava
- 股票買賣:如何把握股票的最佳買賣點?
- leetcode 123 買賣股票的最佳時機 IIILeetCode
- leetcode 122 買賣股票的最佳時機 IILeetCode
- 122. 買賣股票的最佳時機 II
- 力扣之買賣股票的最佳時機力扣
- 買賣股票的最佳時機系列問題
- Leetcode121. 買賣股票的最佳時機LeetCode
- 程式碼隨想錄演算法訓練營 | 121.買賣股票的最佳時機,122.買賣股票的最佳時機II,123.買賣股票的最佳時機III演算法
- 121-簡單-買賣股票的最佳時機
- [Leetcode]123.買賣股票的最佳時機3LeetCode
- LeetCode122. 買賣股票的最佳時機 IILeetCode
- 力扣-121. 買賣股票的最佳時機力扣
- LeetCode-122-買賣股票的最佳時機 IILeetCode
- LeetCode-Java:122. 買賣股票的最佳時機ⅡLeetCodeJava
- 力扣之陣列——買賣股票的最佳時機力扣陣列
- 力扣-122. 買賣股票的最佳時機 II力扣
- 陣列筆試題之買賣股票的最佳時機陣列筆試
- 演算法122. 買賣股票的最佳時機 II演算法
- 程式碼隨想錄演算法訓練營第48天 | 188.買賣股票的最佳時機IV 、309.最佳買賣股票時機含冷凍期、 714.買賣股票的最佳時機含手續費演算法
- LeetCode 188 買賣股票的最佳時機IV HERODING的LeetCode之路LeetCode
- 2020-11-19(122. 買賣股票的最佳時機 II)
- 線性dp:LeetCode122.買賣股票的最佳時機llLeetCode
- LeetCode《買賣股票的最佳時機》系列題目,最詳解LeetCode
- lintcode [python]151. 買賣股票的最佳時機 III你最多可以完成兩筆交易。Python
- leetcode【每日一題】122. 買賣股票的最佳時機 II JavaLeetCode每日一題Java
- 【演算法】【線性表】【陣列】買賣股票的最佳時機演算法陣列
- Day 44 | 714.買賣股票的最佳時機含手續費
- 【演算法】【線性表】【陣列】買賣股票的最佳時機 II演算法陣列
- leetcode 動態規劃 買賣股票的最佳時機含手續費 javaLeetCode動態規劃Java
- 演算法系列-動態規劃(4):買賣股票的最佳時機演算法動態規劃
- [力扣每日一題]714. 買賣股票的最佳時機含手續費力扣每日一題
- Java演算法之動態規劃詳解-買賣股票最佳時機Java演算法動態規劃