news 2026/6/23 19:23:36

代码随想录算法第四十一天| LeetCode121买卖股票的最佳时机、LeetCode122买卖股票的最佳时机Ⅱ、LeetCode123买卖股票的最佳时机Ⅲ

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
代码随想录算法第四十一天| LeetCode121买卖股票的最佳时机、LeetCode122买卖股票的最佳时机Ⅱ、LeetCode123买卖股票的最佳时机Ⅲ

LeetCode 121 买卖股票的最佳时机

题目链接:121.买卖股票的最佳时机

文档讲解:代码随想录

视频讲解:买卖股票的最佳时机

思路与感想:题目的难点在于不知道dp数组的含义怎么设置,当时只想着用一个一维的dp数组表示第i天,却没去从每一天的状态入手,我估摸着即便我想到用二维dp数组表示的话,也大概率是想着0和1表示第i天卖出或买入的行为,而不会想着第i天持有或者不持有这个股票的状态,后者的高明之处在于它让每天与前一天后一天都产生了联系,由此可以思考出递推关系。但是前者光定义每一天的行为,那相当于每一天都是独立的,因为每天都有可能进行买入卖出股票,自然也联系不到一起了。另一个巧妙地地方在于把现金初始化0,相当于买入股票地时候其实是在赊账,这一点也让后续地递推计算方便了很多。

收获:1.股票问题DP数组的设置

class Solution { public int maxProfit(int[] prices) { int[][] dp = new int[prices.length][2]; // 确定dp数组下标含义,dp[i][0]表示第i天不持有股票的最大money数,dp[i][1]表示第天持有股票的最大money数 dp[0][0] = 0; // 第1天不持有股票说明现金还是0 dp[0][1] -= prices[0]; // 第1天持有股票说明就是在第1天买的现金为-prices[0] for (int i = 1; i < prices.length; i++) { // 从左往右递推 dp[i][0] = Math.max(dp[i - 1][0],dp[i - 1][1] + prices[i]); // 第i天不持有股票有两种情况,第一种是第i-1天也不持有股票,即dp[i - 1][0],第二种是第i-1天还持有股票,第i天就卖出取了,即dp[i - 1][1] + prices[i],两个值求最大 dp[i][1] = Math.max(dp[i - 1][1],-prices[i]); // 第i天持有股票也有两种情况,第一种是第i-1天就持有股票了,即dp[i - 1][1],第二种是第i天才买股票,即0 - prices[i],两个值求最大 } return dp[prices.length - 1][0]; // 求最后一天不持有股票的现金数量(肯定比持有股票的现金数多) } }

LeetCode 122 买卖股票的最佳时机 Ⅱ

题目链接:122.买卖股票的最佳时机 Ⅱ

文档讲解:代码随想录

视频讲解:买卖股票的最佳时机 Ⅱ

思路与感想:这道题目上一题唯一的区别就在于可以多次买卖,这一点在上述代码中其实就只有递推dp[i][1]的时候其中一种情况需要改动,正因为可以多次买卖,所以在第i天购入股票的时候,现金可能不为0,因为在此之前可能已经经过多番买卖了,所以应该用dp[i - 1][0]减去prices[i]才行。

收获:1.多次买卖与买卖一次递推公式的区别

class Solution { public int maxProfit(int[] prices) { int[][] dp = new int[prices.length][2]; dp[0][0] = 0; dp[0][1] -= prices[0]; for (int i = 1; i < prices.length; i++) { dp[i][0] = Math.max(dp[i - 1][0],dp[i - 1][1] + prices[i]); dp[i][1] = Math.max(dp[i - 1][1],dp[i - 1][0] - prices[i]); // 区别在于递推dp[i][1]时,如果前一天没持有股票而是第i天才购入的,由于可以多次买卖,所以前面可能已经进行过多番交易了,此时现金不是0而应该时dp[i - 1][0],然后减去第i天的price才是当天持有股票的现金的一种情况 } return dp[prices.length - 1][0]; } }

LeetCode 123 买卖股票的最佳时机 Ⅲ

题目链接:123.买卖股票的最佳时机 Ⅲ

文档讲解:代码随想录

视频讲解:买卖股票的最佳时机 Ⅲ

思路与感想:刚写这道题目的时候想着如果不能够多次买卖的话,那就需要在递推的时候限定购买次数,起初想着是用回溯加动态规划但是发现这样的话那还是跟直接回溯没啥区别,肯定会超时,后面像这样增加DP数组维度用以记录是第几次交易,后面发现如果泛泛记录交易次数是无法确定递推的时候是加上还是减去对应股票值得,就又想着增加一个维度记录是买入还是卖出,觉得挺麻烦感觉应该不是这样做的,后面看完卡哥思路才发现这样做其实也可以做出来只是维度搞复杂了,只需要两个维度即可,只不过用01234表示不同操作状态而已,没必要新增维度。后面递推的话也是两种情况,一种延续前一天状态,一种在当天发生操作,求最大值。最后返回第二次卖出股票的值,一定是最大值,因为它包含了第一次卖出股票的值,如果第一次卖出的股票已经是最大值了,那第二次顶多在当天买入又卖出,值是一样的。

收获:1.状态增加时不仅要想着增加维度,还要想能不能在既有维度上表示新增的状态

class Solution { public int maxProfit(int[] prices) { int[][] dp = new int[prices.length][5];// dp[i][0]表示不操作,dp[i][1]表示第一次持有,dp[i][2]表示第一次不持有,dp[i][3]表示第二次持有,dp[i][4]表示第二次不持有 dp[0][1] -= prices[0]; // 初始现金为0,第一次持有减去对应值 dp[0][3] -= prices[0]; // 第一次不持有后现金为0,即dp[0][2] = 0,在此基础上又第二次持有股票,减去对应值,相当于同一天买入卖出又买入又卖出,最终现金还是0 for (int i = 1; i < prices.length; i++) { dp[i][1] = Math.max(dp[i - 1][1],-prices[i]); // 第一次持有有两种情况,第一种是延续前一天的持有状态,第二种是当天购入股票,下面以此类推 dp[i][2] = Math.max(dp[i - 1][2],dp[i - 1][1] + prices[i]); dp[i][3] = Math.max(dp[i - 1][3],dp[i - 1][2] - prices[i]); dp[i][4] = Math.max(dp[i - 1][4],dp[i - 1][3] + prices[i]); } return dp[prices.length - 1][4]; } }

今天早起把买卖股票的三道题目写完了,难度都一般,花了四个小时不到,理解起来特别容易,很快就写完了,今天没课,上一周忙于pre和做ppt还有六级的事情,导致框架一点没学,这周重启springboot和vue框架,主要是基于springboot和vue框架做前后端分离开发Web,之前学Web已经是一个多月前了,有点遗忘,当时做了个管理系统,希望这次能再多多熟悉Web的开发流程。还有英语口语和日语的学习也要慢慢捡起来了,现在的算法强度慢慢适应花的时间更少了,就要寻找更多能进行价值产出的学习了。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 0:51:08

从GitHub获取Qwen3-8B最新镜像并完成本地化部署

从GitHub获取Qwen3-8B最新镜像并完成本地化部署 在生成式AI迅速渗透各行各业的今天&#xff0c;越来越多开发者和企业开始尝试将大语言模型&#xff08;LLM&#xff09;落地到实际业务中。然而&#xff0c;高昂的API调用成本、数据隐私风险以及网络延迟等问题&#xff0c;让不少…

作者头像 李华
网站建设 2026/6/22 16:59:50

Ubuntu安装完成后配置PyTorch-GPU的完整流程

Ubuntu安装完成后配置PyTorch-GPU的完整流程 在深度学习项目启动的第一天&#xff0c;最让人沮丧的往往不是模型不收敛&#xff0c;而是——torch.cuda.is_available() 返回了 False。 明明装了NVIDIA显卡&#xff0c;也下了PyTorch&#xff0c;为什么就是用不上GPU&#xff1f…

作者头像 李华
网站建设 2026/6/23 16:39:47

购买GPU算力租用Qwen3-14B实例的性价比分析

Qwen3-14B GPU算力租用的性价比深度解析 在当前AI技术快速渗透企业服务的浪潮中&#xff0c;如何以合理的成本获得高质量的语言模型能力&#xff0c;成为许多中小企业和初创团队的核心关切。大模型虽强&#xff0c;但动辄上百GB显存、多卡并行的部署门槛&#xff0c;让不少团队…

作者头像 李华
网站建设 2026/6/23 16:39:47

LobeChat前端性能优化建议:减少加载时间提升访问量

LobeChat前端性能优化建议&#xff1a;减少加载时间提升访问量 在AI聊天界面日益普及的今天&#xff0c;用户对响应速度和交互流畅度的期待已远超从前。一个看似微小的“白屏等待”&#xff0c;可能就足以让访客关闭页面、转向竞品。LobeChat作为一款功能丰富、支持多模型接入的…

作者头像 李华
网站建设 2026/6/23 1:24:39

学术研究新利器:Qwen3-8B开箱即用镜像发布

学术研究新利器&#xff1a;Qwen3-8B开箱即用镜像发布 在高校实验室里&#xff0c;一个研究生正为跑不通大模型环境而焦头烂额——CUDA版本不兼容、PyTorch编译失败、显存爆满……这不是个例。据一项2023年的调研显示&#xff0c;超过60%的AI初学者将“环境配置”列为进入大模型…

作者头像 李华
网站建设 2026/6/23 4:22:39

使用wget命令从清华源下载PyTorch安装包的脚本示例

使用 wget 从清华源下载 PyTorch 安装包的实践与优化 在深度学习项目启动阶段&#xff0c;最令人沮丧的场景之一莫过于&#xff1a;刚配置好环境&#xff0c;执行 pip install torch 却卡在 5% 长达半小时。尤其在国内网络环境下&#xff0c;PyTorch 这类大型依赖的安装常因国…

作者头像 李华