LeetCode-121. 买卖股票的最佳时机
创始人
2025-05-31 12:45:08
0

目录

    • 暴力解
    • 贪心
    • 动态规划

题目来源
121. 买卖股票的最佳时机

暴力解

class Solution {public int maxProfit(int[] prices){if(prices == null || prices.length == 0){return 0;}int max = 0;for(int i = 0;ifor(int j = i+1;jmax = Math.max(max,prices[j]-prices[i]);}}return max;}
}

在这里插入图片描述

贪心

因为股票就买卖一次,那么贪心的想法很自然就是取最左最小值,取最右最大值,那么得到的差值就是最大利润。

class Solution {public int maxProfit(int[] prices){if(prices == null || prices.length == 0){return 0;}int result = 0;int low = Integer.MAX_VALUE;for(int i = 0;ilow = Math.min(low,prices[i]);result = Math.max(result,prices[i]-low);}return result;}
}

在这里插入图片描述

动态规划

动规五部曲分析如下:

  • 1.确定dp数组(dp table)以及下标的含义

dp[i][0] 表示第i天持有股票所得最多现金,本题中只能买卖一次,持有股票之后哪还有现金呢?
其实一开始现金是0,那么加入第i天买入股票现金就是 -prices[i], 这是一个负数。
dp[i][1] 表示第i天不持有股票所得最多现金
注意这里说的是“持有”,“持有”不代表就是当天“买入”!也有可能是昨天就买入了,今天保持持有的状态

  • 2.确定递推公式

如果第i天持有股票即dp[i][0], 那么可以由两个状态推出来
第i-1天就持有股票,那么就保持现状,所得现金就是昨天持有股票的所得现金 即:dp[i - 1][0]
第i天买入股票,所得现金就是买入今天的股票后所得现金即:-prices[i]
那么dp[i][0]应该选所得现金最大的,所以dp[i][0] = max(dp[i - 1][0], -prices[i]);

如果第i天不持有股票即dp[i][1], 也可以由两个状态推出来
第i-1天就不持有股票,那么就保持现状,所得现金就是昨天不持有股票的所得现金 即:dp[i - 1][1]
第i天卖出股票,所得现金就是按照今天股票价格卖出后所得现金即:prices[i] + dp[i - 1][0]
同样dp[i][1]取最大的,dp[i][1] = max(dp[i - 1][1], prices[i] + dp[i - 1][0]);

  • 3.dp数组如何初始化

由递推公式 dp[i][0] = max(dp[i - 1][0], -prices[i]); 和 dp[i][1] = max(dp[i - 1][1], prices[i] + dp[i - 1][0]);可以看出

其基础都是要从dp[0][0]和dp[0][1]推导出来。

那么dp[0][0]表示第0天持有股票,此时的持有股票就一定是买入股票了,因为不可能有前一天推出来,所以dp[0][0] -= prices[0];

dp[0][1]表示第0天不持有股票,不持有股票那么现金就是0,所以dp[0][1] = 0;

  • 4.确定遍历顺序

从递推公式可以看出dp[i]都是由dp[i - 1]推导出来的,那么一定是从前向后遍历。

  • 5.举例推导dp数组

以示例1,输入:[7,1,5,3,6,4]为例,dp数组状态如下:
在这里插入图片描述
代码实现

class Solution {public int maxProfit(int[] prices){if(prices == null || prices.length == 0){return 0;}int[][] dp = new int[prices.length][2];dp[0][0] = -prices[0];dp[0][1] = 0;for(int i =1;idp[i][0] = Math.max(dp[i-1][0],-prices[i]); //持有dp[i][1] = Math.max(dp[i-1][1],dp[i-1][0]+prices[i]);  //不持有。第二个是把前一天持有的卖了}return Math.max(dp[prices.length-1][0],dp[prices.length-1][1]);}
}

在这里插入图片描述

相关内容

热门资讯

【Spring从成神到升仙系列... 👏作者简介:大家好,我是爱敲代码的小黄,独...
人生励志签名100句,qq人生... 1、知识愈浅,自信愈深。——苏联   2、勇敢乃是自信与害怕中间之道。——(希腊)亚里士多德  3、...
安全生产标语二十条,安全生产标... 1、关爱生命 安全发展 2、安全第一 预防为主 综合治理3、广泛深入开展“安全生产月...
关于青春的励志签名,创业励志签... 1、世上最重要的事,不在于我们在何处,而在于我们朝着什么方向走。   2、世上没有绝望的处境,只有对...
拼搏的励志签名,最新或2023... 1、如果你认为学校里的老师过于严厉,那么等你有了老板再回头想一想。   2、世界青睐有雄心壮志的人。...
春运安全标语,春运安全注意事项... 1、文明交通你我他,平安出行迎新春。 2、春运安全连万家,出行平安你我他。3、驾车莫贪杯中酒,平安幸...
访问网络服务-Go对IPC的支... 访问网络服务-Go对IPC的支持 文章目录访问网络服务-Go对IPC的支持一、socket与IPC1...
自己主持婚礼主持词精选 婚礼开...  自己主持婚礼主持词精选(一)  1、新人入场  新人踏着舞步走到一半,庄重登常  新郎:繁花似锦,...
浪婚礼主持词串词顺口溜 濠氬簡... 今天####年#月#日,天空因为今天的喜庆而变得格外晴朗,而大地也因为年青人的无限活力而充满了生机。...
最新或2023(历届)新年跨年... 最新或2023(历届)新年说说祝福大全一:过年要玩好,必须的;早餐别忘了,注意的;烟酒要减少,提醒的...
搞笑婚礼主持词精选 搞笑婚礼主... 开场音乐中 司仪登场 (秋天)  嘘,,,,多安静啊,一点掌声都没有,感谢大家无声的支持。  凉风有...
最新或2023(历届)鼠年qq...  最新或2023(历届)qq空间新年说说大全  一、 新年到来,百无禁忌。东行吉祥,南走顺利,西出平...
大模型落地比趋势更重要,NLP... 全球很多人都开始相信,以ChatGPT为代表的大模型,将带来一场NLP领...
Android开发-Andro... 01  Android UI 1.1  UI 用户界面(User Interface,...
有关于致父母的一封感谢信 给父... 父母的教育素质影响着学前儿童家庭教育的效果和质量,也直接决定着家庭教育的优劣成败。那么有关于致父母的...
有关于写给老师的一封感谢信 给... 感谢信作为一种礼貌性言语行为的载体,其中谢意表达的处理成为写好感谢信的核心环节。下面小编整理了有关于...
有关于致干部家属的感谢信 致干... 感谢信是写信人对给予自己帮助、支持、关心、祝贺、慰问、馈赠的施惠人表示答谢而写的社交礼仪书信。下面小...
婚礼主持词开场白,浪漫婚礼主持... 1、开场白:(神秘花园)  我们每个人都生长在同一个蔚蓝的星球;我们每个人都是从平坦或不平坦的一端开...
有关于致公交司机的感谢信 给公... 公交司机作为影响城市公共交通供给质量和服务满意度的双重介入主体,其个体行为在很大程度上代表了城市综合...
A.机器学习入门算法(三):基... 机器学习算法(三):K近邻(k-nearest neigh...