给你一个整数数组 prices ,其中 prices[i] 表示某支股票第 i 天的价格。
在每一天,你可以决定是否购买和/或出售股票。你在任何时候 最多 只能持有 一股 股票。你也可以先购买,然后在 同一天 出售。
返回 你能获得的 最大 利润 。
第一种方法
class Solution:
def maxProfit(self, prices: List[int]) -> int:
maxprice = 0
left = 0
for right in range(1,len(prices)):
if prices[right]>prices[left]:
price = prices[right]-prices[left]
maxprice+=price
left=right
else:
left=right
return maxprice
第二种方法 - - 贪心算法解决
下面我随便画了一个股票的曲线图,可以看到如果股票一直上涨,只需要找到股票上涨的最大值和股票开始上涨的最小值,计算他们的差就是这段时间内股票的最大利润。如果股票下跌就不用计算,最终只需要把所有股票上涨的时间段内的利润累加就是我们所要求的结果
贪心算法是指,在对问题求解时,总是做出在当前看来是最好的选择。也就是说,不从整体最优上加以考虑,算法得到的是在某种意义上的局部最优解。
那么这道题使用贪心算法也是最容易解决的,只要是上涨的我们就要计算他们的差值进行累加,不需要再找开始上涨的最小值和最大值。为什么能这样计算,我举个例子。
比如a<b<c<d,因为从a到d一直是上涨的,那么最大值和最小值的差值就是d-a,也可以写成(b-a)+(c-b)+(d-c),搞懂了这个公式所有的一切都明白了。如果还不明白,可以想象成数组中前一个值减去
这里只需要计算新数组中正数的和,也就是4+3=7。
代码所示:
def maxProfit(prices):
maxprice = 0
for i in range (0,len(prices)-1):
price = max(prices[i+1]-prices[i],0)
maxprice+=price
return maxprice