贪心算法-递增的三页子序列

题目链接

一、问题描述

给定一个整数数组 nums,判断是否存在长度为3的递增子序列 ,即是否存在下标 i < j < k,使得 nums[i] < nums[j] < nums[k]

  • 存在则返回 true,否则返回 false

二、核心解法

解法1:动态规划(DP)
  • 思路:计算数组的**最长递增子序列(LIS)**的长度,若长度 ≥ 3,则说明存在符合要求的子序列。
  • 实现逻辑
    1. 定义 dp[i] 表示以 nums[i] 结尾的最长递增子序列的长度。
    2. 对每个 i,遍历所有 j < i,若 nums[j] < nums[i],则 dp[i] = max(dp[i], dp[j] + 1)
    3. 遍历 dp 数组,若存在值 ≥ 3,直接返回 true
  • 复杂度 :时间复杂度 O(n²),空间复杂度 O(n)(需存储 dp 数组)。
解法2:贪心算法
  • 思路 :用两个变量 ab 分别记录长度为1长度为2 的递增子序列的最小末尾值 ,遍历数组时更新这两个变量,一旦找到比 b 大的元素,说明存在长度为3的递增子序列。
  • 实现逻辑 (以示例 [2,1,5,0,4,6] 为例):
    1. 初始化 a = ∞b = ∞
    2. 遍历每个元素 x
      • x ≤ a → 更新 a = x(保持长度1的子序列末尾最小);
      • a < x ≤ b → 更新 b = x(保持长度2的子序列末尾最小);
      • x > b → 说明存在 a < b < x,即长度为3的递增子序列,直接返回 true
    3. 遍历结束未找到则返回 false
  • 复杂度 :时间复杂度 O(n)(仅需一次遍历),空间复杂度 O(1)(仅用两个变量),是更优的解法。

三、知识点总结

  1. 问题本质:该问题是「最长递增子序列(LIS)」的特例,只需判断 LIS 长度是否 ≥ 3。
  2. 算法对比
    • 动态规划适用于需要完整计算 LIS 长度的场景,但时间复杂度较高;
    • 贪心解法针对「判断是否存在长度为3的递增子序列」做了优化,时间、空间效率更优。
  3. 贪心策略的核心:维护最小的可能末尾值,让后续更容易找到更长的递增子序列,从而提升效率。
相关推荐
神奇小汤圆3 分钟前
字节面试官:你知道Claude Code的多Agent实现机制吗?
算法
运筹vivo@7 分钟前
LeetCode 2540. 最小公共值
算法·leetcode·职场和发展
小许同学记录成长8 分钟前
轻量正射实现原理技术文档
算法·无人机
阿文的代码库8 分钟前
如何在C++中使用标准库的智能指针
开发语言·c++·算法
城事漫游Molly9 分钟前
方差分析(ANOVA)入门——比较三组或更多组均值的利器
大数据·算法·均值算法·论文笔记·科研统计
Yzzz-F10 分钟前
[专题]最大子矩形问题
算法
WL_Aurora11 分钟前
Python 算法基础篇之查找算法(三):树表查找
python·算法
吃好睡好便好18 分钟前
在Matlab中绘制二维直方图
开发语言·人工智能·学习·算法·matlab
温九味闻醉25 分钟前
关于腾讯广告算法大赛2025项目面试要点
人工智能·算法·机器学习
sheeta199832 分钟前
LeetCode 每日一题笔记 日期:2026.05.15 题目:153. 寻找旋转排序数组中的最小值
笔记·算法·leetcode