一、力扣习题记录
习题买卖股票的最佳时机
给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。
你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。
返回你可以从这笔交易中获取的最大利润。如果你不能获取任何利润,返回 0 。
动态规划做题步骤
1)明确dp(i) 应该表示什么(二维情况:dp(i)(j));
2)根据 dp(i)和 dp(i-1)的关系得出状态转移方程;
3)确定初始条件,如 dp(0)。
二、代码
Python 3
class Solution:
def maxProfit(self, prices: List[int]) -> int:
# 暴力法
n = len(prices)
res = 0
for i in range(n):
for j in range(i+1,n):
res = max(res,prices[j]-prices[i])
return res
# 动态规划思想
n = len(prices)
if n == 0: # 边界问题
return 0
minprice = prices[0]
maxpro = 0
dp = [0] * n # [0] * n 代表list*n重复n次并连接成一个新的数组
for i in range(n):
minprice = min(minprice,prices[i]) # 求遍历数组中的最小值
dp[i] = max(dp[i-1],prices[i]-minprice) # dp[i]代表前i天的利润最大值
return dp[-1] # 返回前n天利润最大值