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

题目链接

一、问题描述

给定一个整数数组 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. 贪心策略的核心:维护最小的可能末尾值,让后续更容易找到更长的递增子序列,从而提升效率。
相关推荐
会编程的土豆10 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移10 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业10 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
空中海11 小时前
Kubernetes 入门基础与核心架构
贪心算法·架构·kubernetes
智者知已应修善业12 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
.54813 小时前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove13 小时前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊13 小时前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法
code_pgf15 小时前
Octo 算法详解-开源通用机器人策略模型技术报告
算法·机器人·开源
嘻嘻哈哈樱桃15 小时前
牛客经典101题题解集--动态规划
java·数据结构·python·算法·职场和发展·动态规划