python—买卖股票的最佳时机

文章目录

      • 题目描述
      • 常规的解法
      • 动态规划

题目描述

给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格。
如果你最多只允许完成一笔交易(即买入和卖出一支股票),设计一个算法来计算你所能获取的最大利润。
注意你不能在买入股票前卖出股票。

示例 1:
输入: [7,1,5,3,6,4]
输出: 5
解释: 在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。
注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格。

示例 2:
输入: [7,6,4,3,1]
输出: 0
解释: 在这种情况下, 没有交易完成, 所以最大利润为 0。

常规的解法

我们可以设置两个变量,一个变量表示当前的最小价格,一个变量表示当前的最大利润。遍历这个数组,先更新目前为止的最小价格,然后再将当前的价格减去当前的最小价格(利润),以此为根据更新最大利润。遍历完数组,返回最大利润即可。

def getMaxProfit(l):
    # minPrice = float("inf") # 正负无穷 如果不好理解可以使用下边的方法
    minPrice = l[0]
    maxProfit = 0
    if len(l) <= 0:
        return
    for i in l[1:]:
        if i < minPrice:
            minPrice = i
        if i - minPrice > maxProfit:
            maxProfit = i - minPrice
    return maxProfit


if __name__ == '__main__':
    l = [7, 1, 5, 3, 6, 4]
    res = getMaxProfit(l)
    print(res)

动态规划

这个问题其实有两个状态,要么持有股票,要么不持有股票。
使用dp[i][0] 表示第i天不持有股票。这种状态由两种状态转移而来,第一:第i-1天不持有股票dp[i-1][0] 第二:第i-1天持有股票,第i天卖了,dp[i-1][1] + price[i]
使用dp[i][1] 表示第i天持有股票。这种状态由两种状态转移而来,第一:第i-1天就持有股票dp[i-1][1] 第二:第i-1天不持有股票,第i天买入,dp[i-1][0]-price[i]

def getMaxProfit(prices):
    if len(prices) == 0:
        return 0
    n = len(prices)
    dp_0_0 = 0  # 不持有
    dp_0_1 = -prices[0]  # 持有
    for i in range(1, n):
        dp_0_0 = max(dp_0_0, dp_0_1 + prices[i])
        dp_0_1 = max(dp_0_1, -prices[i])
    return dp_0_0


if __name__ == '__main__':
    l = [7, 1, 5, 3, 6, 4]
    res = getMaxProfit(l)
    print(res)

你可能感兴趣的:(#,动态规划,python,leetcode,动态规划,数据结构,算法)