输出: 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):
**一、Python所有方向的学习路线**
Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。
![img](https://img-blog.csdnimg.cn/1d40facda2b84990b8e1743f5487d455.png)
![img](https://img-blog.csdnimg.cn/0fc11d4a31bd431dbf124f67f1749046.png)
**二、Python必备开发工具**
工具都帮大家整理好了,安装就可直接上手!![img](https://img-blog.csdnimg.cn/ff266f529c6a46c4bc28e5f895dec647.gif#pic_center)
**三、最新Python学习笔记**
当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。
![img](https://img-blog.csdnimg.cn/6d414e9f494742db8bcc3fa312200539.png)
**四、Python视频合集**
观看全面零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
![img](https://img-blog.csdnimg.cn/a806d9b941c645858c61d161aec43789.png)
**五、实战案例**
纸上得来终觉浅,要学会跟着视频一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。![img](https://img-blog.csdnimg.cn/a353983317b14d3c8856824a0d6186c1.png)
**六、面试宝典**
![在这里插入图片描述](https://img-blog.csdnimg.cn/97c454a3e5b4439b8600b50011cc8fe4.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/111f5462e7df433b981dc2430bb9ad39.png)
###### **简历模板**![在这里插入图片描述](https://img-blog.csdnimg.cn/646863996ac44da8af500c049bb72fbd.png#pic_center)
**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
**[需要这份系统化学习资料的朋友,可以戳这里无偿获取](https://bbs.csdn.net/topics/618317507)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**