news 2026/4/18 13:34:24

面试必看:递增的三元子序列

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
面试必看:递增的三元子序列

LeetCode 334. 递增的三元子序列 题解

题目描述

给定一个整数数组nums,判断数组中是否存在下标满足 i < j < k的三元子序列,使得nums[i] < nums[j] < nums[k]。若存在满足条件的三元组,返回true,否则返回false

补充说明:子序列不要求原数组中的元素连续,仅需保证元素的下标顺序与原数组一致即可。

前置分析

在设计解法前,先梳理本题的核心特征,明确解题的约束条件与优化方向:

  1. 存在性判断:仅需验证是否存在一组符合条件的三元组,无需枚举所有解,可提前终止遍历;
  2. 下标顺序约束i<j<k的要求天然适配单次线性遍历,无需额外处理下标关系;
  3. 固定长度目标:目标子序列长度固定为3,无需适配通用长度的递增子序列问题;
  4. 无全局统计需求:仅需维护局部状态变量,无需存储全量数据,空间复杂度可优化至常数级。

结合以上特征,排除暴力枚举(时间复杂度O(n3)O(n^3)O(n3),效率过低)、动态规划(空间复杂度更高,冗余计算)等方案,贪心算法是本题的最优选择。

算法选择依据

贪心算法的核心思想是在每一步选择中都采取当前状态下的局部最优策略,最终推导出全局的可行解,与本题的特征高度匹配:

  1. 仅需判断可行性,无需计算最优解数值,贪心策略可直接满足需求;
  2. 针对长度为3的递增子序列,仅需维护两个局部变量即可记录状态,空间开销极低;
  3. 线性遍历的过程中,一旦找到符合条件的第三个元素,可立即返回结果,无需遍历完整数组;
  4. 下标顺序约束与贪心算法的单向遍历逻辑完全契合,无逻辑冲突。

解题思路

基于贪心策略,我们通过维护两个关键变量,持续更新数组遍历过程中的局部最小值,逐步缩小寻找目标元素的范围:

  1. 定义变量first:记录遍历过程中当前遇到的最小值,作为三元组的第一个候选元素;
  2. 定义变量second:记录在大于 first的前提下,当前遇到的最小值,作为三元组的第二个候选元素;
  3. 遍历数组中的每一个元素,依次进行判断:
    • 若当前元素小于等于first,更新first为当前元素(替换更小的首候选值,为后续寻找递增元素创造更多可能);
    • 若当前元素大于first且小于等于second,更新second为当前元素(替换更小的次候选值,降低找到第三个递增元素的门槛);
    • 若当前元素大于second,说明已找到满足nums[i]<nums[j]<nums[k]的三元组,直接返回true
  4. 若完整遍历数组后仍未找到符合条件的元素,返回false

边界处理

数组长度小于3时,无法构成三元子序列,可直接返回false,无需执行后续逻辑。

代码实现

本题采用 C++ 语言实现,代码中添加了详细注释,兼顾可读性与执行效率:

usingnamespacestd;classSolution{public:boolincreasingTriplet(vector<int>&nums){intlen=nums.size();// 边界条件:数组长度不足3,直接返回falseif(len<3){returnfalse;}// 初始化两个候选值为整数最大值,保证首次遍历能正常更新intfirst=INT_MAX;intsecond=INT_MAX;for(intnum:nums){if(num<=first){// 更新最小的第一个候选元素first=num;}elseif(num<=second){// 更新比first大的最小第二个候选元素second=num;}else{// 找到大于second的元素,满足递增三元子序列条件returntrue;}}// 遍历完成未找到符合条件的三元组returnfalse;}};

复杂度分析

时间复杂度

算法仅对数组执行一次线性遍历,遍历过程中所有判断与赋值操作均为常数级时间复杂度,因此总时间复杂度为O(n)O(n)O(n),其中nnn为数组nums的长度。

空间复杂度

算法仅使用了lenfirstsecond三个常数级变量,未开辟与输入规模相关的额外存储空间,因此空间复杂度为O(1)O(1)O(1)


总结

  1. 本题利用贪心算法的局部最优特性,仅通过两个变量即可完成状态维护,在时间和空间复杂度上均达到最优;
  2. 解题核心是持续缩小候选值的阈值,用更小的候选值提升后续匹配成功率,同时利用存在性判断的特性提前终止遍历;
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 5:20:41

2026年软件测试公众号热度最高内容深度解析与专业行动指南

随着AI技术的普及和行业标准更新&#xff0c;2026年软件测试公众号内容热度呈现“专业化场景化”特征&#xff0c;阅读量和分享率成为核心指标&#xff0c;算法推荐贡献超50%的流量。从业者对效率提升和职业发展的迫切需求&#xff0c;推动内容向深度、实操性转型&#xff0c;A…

作者头像 李华
网站建设 2026/4/18 8:04:53

住宅代理与数据中心代理在爬虫中的选择

在网络爬虫与数据采集场景中&#xff0c;代理 IP 是突破访问限制、隐藏真实身份、保障采集稳定性的核心组件。其中住宅代理与数据中心代理是最主流的两类方案&#xff0c;二者在来源属性、匿名等级、访问效果、成本与适用场景上存在显著差异。选择不当会直接导致 IP 封禁、采集…

作者头像 李华
网站建设 2026/4/18 7:59:03

论文开题“黑科技”:书匠策AI如何让你的选题“一键开挂”

对于许多论文新手来说&#xff0c;开题报告往往是学术征程的第一道“拦路虎”——选题撞车、文献堆砌、逻辑混乱、格式错漏……这些问题像一团乱麻&#xff0c;让人无从下手。别担心&#xff01;今天要介绍的书匠策AI&#xff08;官网&#xff1a;www.shujiangce.com&#xff0…

作者头像 李华
网站建设 2026/4/18 11:06:43

太流批,桌面图标管理神器

今天给大家推荐两款软件&#xff0c;一款桌面图标管理工具&#xff0c;一款是文件/文件夹时间修改工具&#xff0c;有需要的小伙伴可以下载收藏。 第一款&#xff1a;DesktopOK 大家有没有这样的习惯&#xff1a;桌面的东西要在一个固定的地方你才能找得到&#xff0c;如果你要…

作者头像 李华