LeetCode-121. 买卖股票的最佳时机
创始人
2025-05-31 13:32:12
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]);}
}

在这里插入图片描述

相关内容

热门资讯

香港金融管理局对三家银行采取纪... 北京商报讯(记者 孟凡霞 实习记者 周义力)7月22日,香港金融管理局宣布,根据《打击洗钱及恐怖分子...
原创 突... 美国突然变卦了!就在中美贸易谈判进入关键阶段,美国财长贝森特冷不防抛出新要求——打算在协议里硬塞两条...
深圳新晋13家独角兽企业,福田... 7月18日,2025中国(深圳)独角兽企业大会发布《GEI中国独角兽企业研究报告2025》和《深圳市...
汇划1180亿元!“跨境理财通... 7月21日,记者从人民银行广东省分行获悉,“跨境理财通”自2021年启动以来,极大地促进了粤港澳大湾...
秦洪看盘|热门主线波动不改A股... 来源:澎湃新闻 周二A股市场出现了探底回稳的走势。 早盘由于银行股的疲软,主要股指一度翻绿,升势有受...
股票行情快报:美凯龙(6018... 证券之星消息,截至2025年7月22日收盘,美凯龙(601828)报收于3.07元,上涨0.66%,...
原创 煜... 在全球能源格局加速演变、国内“双碳”目标持续深化的大背景下,电力行业正站在变革的前沿。2025年是“...
星环科技拟港交所上市:年亏损额... 近日,科创板上市公司星环科技(688031.SH)发布公告称,为进一步提高公司综合竞争力,更好地利用...
中国启动水电珠峰水利隧道工程!... 2025年7月,中国雅江集团的成立和雅鲁藏布江下游水电工程的开工,标志着世界水电史迎来新的里程碑。 ...
OpenAI CEO:Deep... 【环球网科技综合报道】7月22日消息,据windowscentral报道称,OpenAI 首席执行官...
国家外汇局贾宁:未来外资配置人... 7月22日,国家外汇管理局国际收支司司长贾宁在国新办新闻发布会上表示,未来外资配置人民币资产仍具有较...
并购 | 深度拆解地方国资收购... 一、交易背景 2023年9月20日晚间,上海雅仕投资发展股份有限公司(以下简称“上海雅仕”)公告称...
21日豆二上涨0.19%,最新... 来源:新浪期货 新浪期货 根据交易所数据,截至7月21日收盘主力合约豆二2509,涨跌+0.19%,...
兴证资管国企红利优选混合发起式... AI基金兴证资管国企红利优选混合发起式A(023169)披露2025年二季报,第二季度基金利润112...
专访新辰商业集团联合创始人及C... 在当前商业环境持续变革的背景下,社区商业正逐步成为商业领域的重要发展方向。新辰商业作为这一领域的后起...
与美国斗了整整七年,中国总结出... 与美国斗了整整七年,中方总结出4句话,想看美国是否吸取了教训 国新办日前召开系列主题新闻发布会,商务...
以“诚”破局,利他共生——稻盛... 在中国民营经济迈向高质量发展的关键阶段,企业呼唤更加坚定的精神信仰与先进的经营哲学。6月8日,稻盛和...
詹记桃酥频现日期乱象,有消费者... 近日,有消费者爆料称,其在连锁中式糕点品牌詹记桃酥(下称“詹记”)门店买到了“未来蛋糕”,门店回应称...
李开复:零一万物AI Agen... 李开复入场做AI Agent智能体。 7月22日消息,零一万物创始人兼CEO李开复博士今天上午宣布,...