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]);}
}

在这里插入图片描述

相关内容

热门资讯

原创 印... 2025年11月,印度五大炼油企业在制裁截止日11月21日之前,大规模囤积俄罗斯石油,在12月份没有...
收评:创业板指探底回升涨超1%... 【收评:创业板指探底回升涨超1% 商业航天概念爆发】财联社1月22日电,市场午后震荡回升,三大指数集...
富国消费主题混合C基金近3年单... 近期,富国基金旗下富国消费主题混合基金的表现引起市场关注。 富国消费主题混合基金成立于2014年12...
宏利基金被曝与特斯拉存在诉讼 ... 近期,上海市高级人民法院披露的一则开庭公告显示,特斯拉(上海)有限公司已起诉宏利基金管理有限公司(下...
95亿消费电子大佬,拟“接盘”... 雷达财经出品 文|丁禹 编|孟帅 1月20日,港股上市公司 TCL电子联手索尼,抛出一则震动消费电子...
TikTok美国出售交易预计本... 据美国数字新闻媒体SEMAFOR报道,中美双方已达成协议,以美国投资者为主的财团将参与TikTok美...
金饰克价,1500元!“轻黄金... 近日,首饰黄金每克报价突破1500元引发热议。1月22日,中国证券报记者走访北京地区多家品牌金店看到...
2025年离境退税销售额同比增... 2025年,上海入境游迎来强势增长,全年累计接待入境游客创历史新高,达到936.02万人次,同比大幅...
邵东市举办“讲台育桃李,健康护... 大众卫生报·新湖南客户端1月20日讯(通讯员 曾秀丽 罗邵陵)为提升女性健康素养,强化自我保护意识,...
华翔股份大宗交易折价成交67.... 华翔股份01月22日大宗交易平台共发生4笔成交,合计成交量67.50万股,成交金额1150.88万元...
年内已经上涨37%,明早的英特... 今年以来,英特尔股价累计涨幅已达37%,1月21日收盘价报54.25美元,创2022年1月以来新高。...
阿里巴巴股价突然直线拉升,市值... 北京时间1月22日晚,阿里巴巴美股直线拉升,股价站上180美元,创去年11月以来新高。截至发稿前阿里...
泓德红利优选混合(LOF)A:... AI基金泓德红利优选混合(LOF)A(501227)披露2025年四季报,第四季度基金利润249.8...
金饰克价,逼近1500元! 在地缘局势紧张加剧 市场风险规避情绪高涨背景下 现货黄金以及黄金和白银期货价格 20日大幅上涨 再创...
三个月涨近1000美元,盘点黄... 近期,投资者的担忧情绪持续升温。无论是债券收益率走低、股市估值高企,还是特朗普的政策不确定性,都让他...
净利润16.1亿元左右 210... 今日聚焦 【兆易创新:2025年净利同比预增46%左右 存储行业周期稳步上行供需结构优化推动产品价量...
IPO雷达|惠康科技遭暂缓审议... 深圳商报·读创客户端记者 宁可坚 1月22日晚间,据深交所官网,宁波惠康工业科技股份有限公司(简称“...
大寒节气别瞎吃:学会这几招,轻... 寒冬已至,转眼就到了今年的最后一个节气——大寒。和小寒差不多,大寒时节通常是指寒冷到极致的天气。这个...
不到两月,卖爆300万!老牌肉... 从“朱泾方肉”到“唐小厨”食养产品,一家老牌肉企的健康突围与新赛道试验 在快速更迭的消费市场中,食品...
广州2025“拿地冠军”背后的... 2025年广州经济走出了U字形反弹的良好势头。同时,与上下游数十个产业紧密关联的房地产市场,亦在持续...