news 2026/6/10 3:19:47

day162—递归—买卖股票的最佳时机Ⅱ(LeetCode-122)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
day162—递归—买卖股票的最佳时机Ⅱ(LeetCode-122)

题目描述

给你一个整数数组prices,其中prices[i]表示某支股票第i天的价格。

在每一天,你可以决定是否购买和/或出售股票。你在任何时候最多只能持有一股股票。然而,你可以在同一天多次买卖该股票,但要确保你持有的股票不超过一股。

返回你能获得的最大利润

示例 1:

输入:prices = [7,1,5,3,6,4]输出:7解释:在第 2 天(股票价格 = 1)的时候买入,在第 3 天(股票价格 = 5)的时候卖出, 这笔交易所能获得利润 = 5 - 1 = 4。 随后,在第 4 天(股票价格 = 3)的时候买入,在第 5 天(股票价格 = 6)的时候卖出, 这笔交易所能获得利润 = 6 - 3 = 3。 最大总利润为 4 + 3 = 7 。

示例 2:

输入:prices = [1,2,3,4,5]输出:4解释:在第 1 天(股票价格 = 1)的时候买入,在第 5 天 (股票价格 = 5)的时候卖出, 这笔交易所能获得利润 = 5 - 1 = 4。 最大总利润为 4 。

示例 3:

输入:prices = [7,6,4,3,1]输出:0解释:在这种情况下, 交易无法获得正利润,所以不参与交易可以获得最大利润,最大利润为 0。

提示:

  • 1 <= prices.length <= 3 * 104
  • 0 <= prices[i] <= 104

解决方案:

这段代码是基于记忆化递归的方式求解 “无限次买卖股票的最佳时机” 问题,在你原有递归思路的基础上,仅做了最小化修改(增加记忆化缓存、规范边界值),既保留了核心递归逻辑,又解决了纯递归的超时和栈溢出问题,能高效处理大数据量用例。

核心逻辑

  1. 核心定义

    • memo:二维记忆化数组(len×2),memo[end][0/1]缓存dfs(end, is)的结果(0 = 不持有股票,1 = 持有股票),避免重复递归计算;
    • dfs(end, is, nums):返回从第 0 到第end天,在is状态(true= 持有、false= 不持有)下能获得的最大利润。
  2. 递归边界

    • end < 0(所有天数遍历完毕):
      • is=true(仍持有股票),返回-0xFFFF(极小值,代表非法状态 —— 交易结束时持有股票无利润);
      • is=false(不持有股票),返回 0(无交易时利润为 0)。
  3. 记忆化优化:计算dfs(end, is)前,先检查memo[end][state]state为 0/1 对应不持有 / 持有),若不为 - 1 则直接返回缓存值,避免重复递归。

  4. 状态转移(核心逻辑)

    • 持有股票(is=true):利润取 “继续持有(不操作)” 和 “卖出股票(转为不持有,利润 - 当前股价)” 的最大值;
    • 不持有股票(is=false):利润取 “继续不持有(不操作)” 和 “买入股票(转为持有,利润 + 当前股价)” 的最大值;
    • 计算结果存入memo缓存后返回。
  5. 主函数逻辑:初始化记忆化数组,调用dfs(len-1, false, prices)(从最后一天、不持有股票的初始状态开始计算),返回最终最大利润。

关键特点

  • 最小化修改:完全保留你 “从后往前递归 + 持有 / 不持有状态” 的核心思路,仅增加记忆化和规范边界值;
  • 效率优化:记忆化将时间复杂度从O(2n)降至O(n),解决了大数据量超时 / 栈溢出问题;
  • 逻辑兼容:能正确处理空数组、单调涨跌等边界场景,返回合理的最大利润。

总结

  1. 核心思路:在你原有递归逻辑基础上,通过记忆化缓存避免重复计算,是对纯递归的高效优化;
  2. 关键设计:用二维数组缓存(end, 持有/不持有)状态的结果,是递归优化的核心;
  3. 功能效果:能稳定通过 n=60 甚至更大的股票价格数组用例,返回正确的最大利润。

函数源码:

class Solution { public: vector<vector<int>> memo; // 仅修改该函数:增加记忆化+修正状态转移符号+规范边界值 int dfs(int end, bool is, vector<int>& nums) { int len = nums.size(); if(end < 0) { // 边界值修正:用INT_MIN表示持有股票的非法状态,更规范 if(is) return -0xFFFF; return 0; } int state = is ? 1 : 0; // 0=不持有,1=持有 if (memo[end][state] != -1) { return memo[end][state]; } int res; if(is) { res = max(dfs(end-1, true, nums), dfs(end-1, false, nums) - nums[end]); } else { res = max(dfs(end-1, false, nums), dfs(end-1, true, nums) + nums[end]); } // 缓存当前状态的结果 return memo[end][state] = res; } int maxProfit(vector<int>& prices) { int len = prices.size(); if (len == 0) return 0; // 空数组边界处理 // 初始化记忆化数组(len行2列,初始值-1表示未计算) memo.assign(len, vector<int>(2, -1)); // max(0, ...) 确保利润不会为负(无交易时利润为0) return dfs(len-1, false, prices); } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/30 16:52:21

学霸同款8个一键生成论文工具,研究生高效写作必备!

学霸同款8个一键生成论文工具&#xff0c;研究生高效写作必备&#xff01; 论文写作的“隐形助手”&#xff1a;AI 工具如何改变研究生的学习节奏 在当今学术研究日益复杂的背景下&#xff0c;研究生们面临着前所未有的挑战。无论是论文选题、文献综述&#xff0c;还是数据整理…

作者头像 李华
网站建设 2026/5/29 5:26:56

James 个人介绍(用于企业数字化服务咨询)

专业背景与核心经验本人拥有20 年全球化实施、数字化转型与客户服务复合经验&#xff0c;核心聚焦跨国企业及中资出海企业&#xff0c;提供数字化转型全生命周期解决方案&#xff1b;擅长将企业业务战略与技术架构深度融合&#xff0c;推动全球运营体系的智能化升级、合规化管理…

作者头像 李华
网站建设 2026/6/10 5:34:34

Cadence推出人工智能语音助手Tensilica HiFi iQ DSP IP

来源&#xff1a;维度网 Cadence今日推出Tensilica HiFi iQ DSP IP&#xff0c;作为其HiFi DSP系列第六代产品&#xff0c;专为下一代语音人工智能及沉浸式音频应用打造全新架构。随着家庭娱乐、车载信息娱乐及智能手机市场对语音人工智能和音频处理需求的激增&#xff0c;HiF…

作者头像 李华
网站建设 2026/5/9 21:08:56

C#每日面试题-简述异常处理

C#每日面试题-简述异常处理 在C#开发与面试中&#xff0c;异常处理是衡量代码健壮性与开发者基础能力的核心考点。面试官不仅会问“如何捕获异常”&#xff0c;更关注“异常的本质是什么”“如何合理设计异常处理逻辑”“底层执行机制”等深度问题。本文从入门到进阶&#xff0…

作者头像 李华
网站建设 2026/6/10 3:35:08

基于springBoot的高校大学生党建系统设计与实现

高校大学生党建系统的背景 高校大学生党建系统是信息化时代背景下&#xff0c;高校党建工作与数字化技术深度融合的产物。随着高校学生党员数量逐年增加&#xff0c;传统党建管理模式面临效率低、数据分散、流程繁琐等问题。该系统通过整合党员发展、教育、管理、服务等功能模…

作者头像 李华
网站建设 2026/6/10 9:05:30

Java基于SSM+JSP的高校师资管理系统的设计与实现

项目说明 随着信息技术的飞速发展&#xff0c;高校信息化水平成为衡量一所高校综合实力的重要标准之一。传统的师资管理方式通常依赖于人工操作&#xff0c;工作量大且容易出错。为了提高师资信息的管理水平我们开发了本系统&#xff0c;本系统主要实现了教师信息管理&#xff…

作者头像 李华