当前位置: 首页 > article >正文

【算法日记】Day 9 动态规划专题——最长递增子序列问题及扩展

Abstract#动态规划#最长递增子序列#二分查找#排序1. 题目题目LeetCode 354. 俄罗斯套娃信封核心思路先将信封按宽度升序排序若宽度相同则按高度降序排序。然后对排序后的高度序列求最长递增子序列LIS的长度即为最多能套娃的信封数。宽度相同按高度降序是为了避免相同宽度的信封互相套娃因为宽度相等不能嵌套降序后高度不会递增从而不会错误地计入LIS。复杂度时间复杂度O ( n l o g n ) O(n log n)O(nlogn)排序O ( n l o g n ) O(n log n)O(nlogn) LIS二分O ( n l o g n ) O(n log n)O(nlogn)空间复杂度O ( n ) O(n)O(n)存储 ends 数组。2. 代码classSolution{public:boolcompare(vectorinta,vectorintb){returna[0]!b[0]?a[0]b[0]:a[1]b[1];}// 二分查找第一个num的位置ends数组递增intBinarySearch(vectorintends,intlen,intnum){intl0,rlen-1,m,ans-1;while(lr){ml((r-l)1);if(ends[m]num){rm-1;ansm;}elselm1;}returnans;}intmaxEnvelopes(vectorvectorintenvelopes){intnenvelopes.size();sort(envelopes.begin(),envelopes.end(),compare);vectorintends(n);// ends[i]表示长度为i 1的递增子序列的最小末尾值intlen0;for(inti0,find;in;i){findBinarySearch(ends,len,envelopes[i][1]);if(find-1)ends[len]envelopes[i][1];elseends[find]envelopes[i][1];}returnlen;}};3. 心得LIS问题优化该问题本质上是一个二维偏序LIS问题在题目条件下可以借助排序转化为简单的一维LIS问题。尽管都是一维但与模板题见相关题目第一题不同的是该问题不能直接用经典DP数组来求解时间复杂度为O ( n 2 ) O(n^2)O(n2)在该题的数据量下会超时。应该使用LIS的优化解法引入数组ends表示各个长度的递增子序列的最小末尾值随后在遍历主数组的过程中抓住ends数组递增的特点利用二分搜索寻找最左侧大于等于主数组当前位置数的元素并由此更新ends最终ends的长度即为LIS的长度。传参避免拷贝在自定义比较函数compare或二分查找函数中参数应使用引用传递如vectorint a而不是值传递。如果传值每次调用都会拷贝整个vector产生额外的内存和时间开销对于大数据量如n10 5 10^5105会直接内存超限。另外一种比较直接的解决方案是设置全局变量避免传参。静态比较函数自定义比较函数在类内需要声明为static否则sort无法调用。4. 相关题目LeetCode 300. 最长递增子序列LeetCode 646. 最长数对链LeetCode 2111. 使数组 K 递增的最少操作次数

相关文章:

【算法日记】Day 9 动态规划专题——最长递增子序列问题及扩展

Abstract:#动态规划 #最长递增子序列 #二分查找 #排序 1. 题目 题目:LeetCode 354. 俄罗斯套娃信封核心思路:先将信封按宽度升序排序,若宽度相同则按高度降序排序。然后对排序后的高度序列求最长递增子序列(LIS&…...

STM32总线架构解析与性能优化实战

1. STM32单片机内部总线架构概述作为嵌入式开发者,理解STM32单片机的内部总线结构是优化代码性能的关键。在Cortex-M3架构的STM32F1系列中,总线系统就像一座精心设计的立交桥网络,各司其职又相互配合。我第一次调试DMA传输卡顿时,…...

【typst-rs】greet.rs文件

以下是对greet.rs的详细解析。 use std::io::{self, Read};/// This is shown to users who just type typst the first time. #[rustfmt::skip] const GREETING: &str color_print::cstr!("\ <s>Welcome to Typst, we are glad to have you here!</> ❤…...

嵌入式系统软件抗干扰技术实战解析

1. 嵌入式系统抗干扰技术概述在工业控制、智能家居和物联网设备等嵌入式应用场景中&#xff0c;电磁干扰、电源波动等环境因素常常导致系统运行异常。作为一名有十年嵌入式开发经验的工程师&#xff0c;我处理过数十起由干扰引起的系统故障案例。硬件抗干扰措施如屏蔽、滤波固然…...

从《节奏医生》到你的游戏:拆解Koreographer Pro版如何实现高级音频集成(Wwise/FMOD)

从《节奏医生》到你的游戏&#xff1a;Koreographer Pro版如何实现高级音频集成&#xff08;Wwise/FMOD&#xff09; 在《节奏医生》这类音游中&#xff0c;玩家按键与音乐节拍的完美同步是游戏体验的核心。这种精准的音频同步背后&#xff0c;往往需要复杂的音频中间件集成。对…...

I2C总线原理与应用实战指南

1. I2C总线基础概念解析I2C&#xff08;Inter-Integrated Circuit&#xff09;总线是飞利浦半导体&#xff08;现NXP&#xff09;在1980年代开发的一种同步、多主从架构的串行通信总线。作为一名嵌入式工程师&#xff0c;我几乎在每个项目中都会用到这个看似简单却功能强大的两…...

从零开始:在RK3588上运行RKNN版YOLOv5目标检测(保姆级教程)

从零开始&#xff1a;在RK3588上运行RKNN版YOLOv5目标检测&#xff08;保姆级教程&#xff09; RK3588作为Rockchip新一代旗舰级SoC&#xff0c;其内置的NPU模块为边缘计算场景提供了强大的AI推理能力。本教程将手把手带您完成YOLOv5目标检测模型在RK3588开发板上的完整部署流程…...

显示器EDID数据解析全攻略:从制造商ID到色彩特性的秘密

显示器EDID数据解析全攻略&#xff1a;从制造商ID到色彩特性的秘密 当你连接一台新显示器时&#xff0c;操作系统是如何知道它的最佳分辨率和刷新率的&#xff1f;答案就藏在EDID&#xff08;Extended Display Identification Data&#xff09;这个小小的数据块中。EDID是显示器…...

ESP32伺服与PWM控制库:硬件自适应资源管理

1. 项目概述ESP32ServoController 是一款专为 ESP32 系列微控制器设计的高性能 PWM 与伺服控制库。它并非对 Espressif 官方 LEDC&#xff08;LED Control&#xff09;外设驱动的简单封装&#xff0c;而是基于其硬件架构进行深度抽象与工程化重构的底层控制框架。该库的核心设计…...

双Token无感刷新:从登录到重试的完整链路解析

1. 双Token机制的核心原理 想象一下你住在一个高档小区&#xff0c;门禁卡就是你的通行证。普通门禁卡&#xff08;Access Token&#xff09;有效期只有30分钟&#xff0c;而物业还给你一张备用卡&#xff08;Refresh Token&#xff09;有效期长达7天。当普通卡过期时&#xff…...

2025届必备的五大AI辅助写作工具解析与推荐

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 目前&#xff0c;在学术论文以及职场报告等这些内容生产场景当中&#xff0c;对于文本原创性…...

一道KMP统考真题彻底讲透:nextval与滑动距离的本质我

一、各自优势和对比 这是检索出来的数据&#xff0c;据说是根据第三方评测与企业数据&#xff0c;三款产品在代码生成质量上各有侧重&#xff1a; 产品 语言优势 场景亮点 核心差异 百度 Comate C核心代码质量第一&#xff1b;Python首生成率达92.3% SQL生成准确率提升35%&…...

零基础玩转OpenClaw:Qwen2.5-VL-7B多模态模型入门指南

零基础玩转OpenClaw&#xff1a;Qwen2.5-VL-7B多模态模型入门指南 1. 为什么选择OpenClawQwen2.5-VL组合 去年夏天&#xff0c;当我第一次看到同事用自然语言指令让AI自动整理会议纪要时&#xff0c;内心受到了巨大冲击。经过两周的折腾&#xff0c;我终于在自己的MacBook上搭…...

YOLO11 改进 - 特征融合 | MSAA多尺度注意力聚合模块, 多尺度卷积融合与双通道注意力机制

前言 本文介绍了将多尺度注意力聚合(MSAA)模块与YOLO11结合的方法。MSAA是CM - UNet中用于优化编码器特征、强化跳跃连接的核心模块,能解决遥感图像物体尺度差异大、多尺度特征融合弱的问题。它采用空间与通道双分支并行处理,先对输入的相邻三层特征进行拼接,再分别进行空…...

YOLO26改进 - 注意力机制 | EMA (Efficient Multi-Scale Attention) 高效多尺度注意力:跨空间学习与多分支协同增强特征表征,优化多尺度目标检测

前言 本文介绍了高效多尺度注意力(EMA)模块及其在YOLO26中的结合应用。现有注意力机制在通道维度缩减时可能影响深度视觉表示,EMA模块通过结合通道和空间信息、采用多尺度并行子网络结构等创新点,实现了高效的多尺度注意力机制。其基本原理包括通道和空间注意力结合、多尺…...

嵌入式舵机精确控制:基于硬件定时器的PWM脉宽稳定实现

1. Servo库技术解析&#xff1a;面向嵌入式系统的单路舵机精确控制实现1.1 库定位与工程价值Servo库是一个轻量级、面向资源受限嵌入式平台的单路舵机控制库。其核心设计哲学并非追求功能堆砌&#xff0c;而是聚焦于时间精度、脉宽稳定性与硬件抽象解耦三大关键指标。在STM32F0…...

职场人AI生存指南:10个核心技能,让你不被AI淘汰反而被赋能

掌握AI工具的基础应用职场人需要熟悉主流AI工具的操作&#xff0c;如ChatGPT、Copilot、Notion AI等。了解这些工具的基本功能&#xff0c;如文本生成、数据分析、自动化流程等&#xff0c;能够提升工作效率。定期关注AI工具的更新&#xff0c;学习新功能的应用场景。培养数据思…...

打工人必备!8个AI办公神器,每天准时下班不是梦

文档处理工具Notion AI 集成在Notion中的AI功能&#xff0c;支持自动生成文档大纲、会议纪要整理、多语言翻译。通过自然语言输入需求&#xff0c;快速输出结构化内容&#xff0c;适合项目管理与知识库搭建。ChatPDF 上传PDF文件后可直接对话式提问&#xff0c;提取关键信息或总…...

从PyTorch到FPGA:手把手教你将MobileNetV2模型部署到Zynq平台(附完整代码)

从PyTorch到FPGA&#xff1a;手把手教你将MobileNetV2模型部署到Zynq平台&#xff08;附完整代码&#xff09; 在边缘计算领域&#xff0c;FPGA因其低延迟、高能效和可重构特性&#xff0c;正成为轻量级CNN模型部署的理想选择。本文将带您完成一个从PyTorch模型训练到Xilinx Zy…...

嵌入式C语言设计模式实践:观察者与责任链模式

1. 嵌入式软件开发中的设计模式应用背景在传统认知中&#xff0c;嵌入式系统开发往往与"资源受限"、"底层硬件"、"效率优先"等标签紧密关联。早期的嵌入式设备功能单一&#xff0c;业务逻辑简单&#xff0c;开发者更关注代码的执行效率和硬件资源…...

STM32duino双VL6180X ToF传感器驱动库深度解析

1. 项目概述STM32duino X-NUCLEO-6180XA1 是一个面向 Arduino 兼容生态&#xff08;特别是基于 STM32 的开发板&#xff0c;如 NUCLEO-F401RE、NUCLEO-F411RE、NUCLEO-L476RG 等&#xff09;的硬件抽象库&#xff0c;专为驱动意法半导体&#xff08;STMicroelectronics&#xf…...

【渗透工具】Venom多级代理实战:从零构建内网渗透通道

1. Venom工具入门&#xff1a;多级代理的核心价值 第一次接触Venom是在去年的一次内网渗透项目中。当时客户的内网结构复杂&#xff0c;常规代理工具难以穿透多层网络&#xff0c;直到同事推荐了这个用Go语言开发的神器。简单来说&#xff0c;Venom就像个数字隧道挖掘机&#x…...

嵌入式裸机开发中的轻量级定时调度方案

1. SmartTimer&#xff1a;裸机环境下的轻量级定时调度方案在嵌入式开发中&#xff0c;定时任务管理是个永恒的话题。我最近在做一个空气质量监测项目时&#xff0c;发现传统的裸机编程方式在处理多个定时任务时显得力不从心。硬件定时器资源有限&#xff0c;软件标志位管理又容…...

6000万吨产能承压 卫星化学迎来战略窗口期

据新华社报道&#xff0c;伊朗法尔斯通讯社7日凌晨援引未具名消息源报道&#xff0c;沙特阿拉伯东北部朱拜勒工业区当天发生爆炸&#xff0c;系遭到大范围打击。据悉&#xff0c;朱拜勒工业区是全球重要石化生产基地之一&#xff0c;年产量约6000万吨石化产品&#xff0c;占全球…...

10个经典C语言开源项目深度解析

1. 精选C语言开源项目解析作为一名在系统级编程领域摸爬滚打多年的开发者&#xff0c;我深知优秀的C语言项目对技术成长的帮助。今天要分享的这10个项目&#xff0c;每个都是经过时间检验的经典之作&#xff0c;代码量控制在3万行以内&#xff0c;特别适合作为学习范本。这些项…...

2026届必备的十大AI科研网站解析与推荐

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 伴随人工智能技术的迅猛发展&#xff0c;AI论文工具已然成为学术写作范畴的关键辅助方式&…...

2025最权威的六大AI论文神器实际效果

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 关于论文一键生成的技术&#xff0c;它借助了先进的自动化算法&#xff0c;还有自然语言处理…...

用好AI的五个习惯

五个习惯一、善于拆解问题核心逻辑&#xff1a;AI是执行者&#xff0c;人是设计者。对项目的全流程和细节了如指掌&#xff0c;能够将复杂的大问题拆解为具体的、AI可执行的子任务。二、上下文管理大师核心逻辑&#xff1a;理解模型极限&#xff0c;追求高效输出。当前AI模型&a…...

STM32 GPIO工作模式详解与应用指南

1. STM32 GPIO工作模式深度解析作为一名嵌入式开发工程师&#xff0c;我经常需要与STM32的GPIO打交道。GPIO&#xff08;General Purpose Input/Output&#xff09;作为单片机最基础也最常用的外设&#xff0c;其工作模式的选择直接影响着系统稳定性和功能实现。今天我将结合自…...

MultiSerial:单UART多通道串行通信复用库

1. 项目概述MultiSerial 是一个面向嵌入式系统的多字节串行通信抽象库&#xff0c;其核心设计目标是在单个物理串口&#xff08;UART/USART&#xff09;上安全、可靠地复用多个逻辑通信通道&#xff0c;实现“一串口多路数据流”的工程需求。该库不依赖特定硬件平台或RTOS&…...