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

题目链接

一、问题描述

给定一个整数数组 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 小时前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
To_OC20 小时前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC20 小时前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK1 天前
线段树维护区间 k 次方和
c++·数学·算法·stl
_清歌1 天前
DSpark 深度解读:DeepSeek-V4 如何用「半自回归」把推理速度提升 85%
算法
统计实现局1 天前
SVD 的三步走:双对角化、Givens 收敛、排序
算法
躬行见万象1 天前
《VLA 系列》UniLab 强化训练 | G1 机器人 |复现
算法
统计实现局1 天前
对称不定分解(Bunch-Kaufman):为什么 Cholesky 不够用
算法
统计实现局1 天前
dqrsl 拆解:拿着 QR 结果能算出哪 5 种东西
算法