本文共 912 字,大约阅读时间需要 3 分钟。
给定一个数组,该数组表示每天的股票价格,目标是通过有限的买卖交易操作,最大化总利润。允许进行多次买卖交易,但必须在新交易开始之前完成前一次交易。也就是说,必须先卖出股票后再购买新的股票。
这个问题可以通过寻找股票价格的涨幅来解决。具体来说,我们需要找出所有连续交易日中,股票价格上升的部分,并将这些利润累加起来。这样可以保证在每次价格上涨的情况下,都能获取到相应的利润。
具体步骤如下:
res
来记录最终的利润。prices[i]
,计算它相对于前一个元素 prices[i-1]
的价格差值。res
中。res
,即为最大利润。class Solution: def maxProfit(self, prices: List[int]) -> int: n, res = len(prices), 0 for i in range(1, n): diff = prices[i] - prices[i-1] if diff > 0: res += diff return res
n
为数组长度,res
为0,用于记录利润。res
中。res
,表示最大利润。这个解决方案的核心在于利用股票价格的上涨部分来计算利润。每次找到一个价格上涨,就能立即从中获利。虽然看起来简单,但这种方法的正确性是经过验证的。
基于这个思路,算法的时间复杂度为 O(n),非常高效,适合处理大规模数据。此外,这种方法避免了复杂的交易逻辑,确保了一定能够找到最优解。
如果需要进一步的优化,可以考虑使用更多的交易策略,但在本题中,问题允许进行尽可能多的交易,因此上述方法已经是最优解了。
转载地址:http://ekaez.baihongyu.com/