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

优先队列和单调队列(双端队列实现的)

这里写自定义目录标题

  • 一、优先队列与单调队列
  • 二、优先队列
    • 2.1 概念
    • 2.2 增删查 + 判空
    • 2.3 示例代码
  • 三、双端队列
  • 四、单调队列
    • 4.1 单调递增队列
    • 4.2 单调递减队列

一、优先队列与单调队列

二、优先队列

2.1 概念

一种特殊的队列,它与普通队列的主要区别在于元素的出队顺序是根据元素的优先级来决定的,而不是按照元素进入队列的顺序。具体来说,优先队列中的元素具有优先级,优先级较高的元素会比优先级较低的元素先被移除。
原理: 大根堆(默认大根堆)或者小根堆。

2.2 增删查 + 判空

1.增: push()
2.删: pop()
3.查: top()
4.元素个数: size()
5.判空: empty()

2.3 示例代码

#include <iostream>
#include <queue>int main() {// 创建一个优先队列,默认使用最大堆std::priority_queue<int> pq;// 向优先队列中插入元素pq.push(10);pq.push(5);pq.push(20);pq.push(15);pq.pop();// 输出并删除优先队列中的元素(按优先级高低)while (!pq.empty()) {std::cout << pq.top() << " ";  // 输出堆顶元素pq.pop();  // 删除堆顶元素}//15 10 5return 0;
}

三、双端队列

  • 增:push_back() / push_front()
  • 删:pop_back() / pop_front()
  • 查:back() / front() / at() / []
  • 判空:size() / empty()
#include <iostream>
#include <deque>using namespace std;int main() {// 创建一个双端队列deque<int> dq;// 向队列两端插入元素dq.push_front(10);  // 前端插入 10dq.push_back(20);   // 后端插入 20dq.push_front(5);   // 前端插入 5dq.push_back(30);   // 后端插入 30//5 10 20 30// 输出队列的大小cout << "队列的大小: " << dq.size() << endl;// 访问队列的前端和后端元素cout << "队列前端元素: " << dq.front() << endl;cout << "队列后端元素: " << dq.back() << endl;// 删除队列前端和后端的元素dq.pop_front();  // 删除前端元素dq.pop_back();   // 删除后端元素//10 20// 输出删除后的队列cout << "删除后的队列: ";for (auto it = dq.begin(); it != dq.end(); ++it) {cout << *it << " ";}cout << endl;// 使用 at() 访问元素cout << "索引 0 处的元素: " << dq.at(0) << endl;// 使用下标运算符访问元素cout << "索引 0 处的元素: " << dq[0] << endl;// 检查队列是否为空if (dq.empty()) {cout << "队列为空" << endl;} else {cout << "队列不为空" << endl;}// 清空队列dq.clear();cout << "清空后的队列大小: " << dq.size() << endl;return 0;/*队列的大小: 4队列前端元素: 5队列后端元素: 30删除后的队列: 10 20 索引 0 处的元素: 10索引 0 处的元素: 10队列不为空清空后的队列大小: 0*/   
}

四、单调队列

一般是基于双端队列(deque)实现的
应用:滑动窗口,区间最值方法。

4.1 单调递增队列

1.概念

  • 队列中的元素按从小到大的顺序排列。
  • 每次插入新元素时,保证队列的元素保持递增顺序。如果新元素小于队列中的某些元素,则删除这些元素,直到新元素大于队列的尾部元素。

示例

vector<int> minSlidingWindow(vector<int>& nums, int k) {vector<int> result;deque<int> dq;  // 单调递增队列for (int i = 0; i < nums.size(); i++) {// 移除不在窗口中的元素if (!dq.empty() && dq.front() < i - k + 1) {dq.pop_front();}// 移除队尾元素,使队列保持递增while (!dq.empty() && nums[dq.back()] >= nums[i]) {dq.pop_back();}// 加入新元素dq.push_back(i);// 队头元素是当前窗口的最小值if (i >= k - 1) {result.push_back(nums[dq.front()]);}}return result;
}

4.2 单调递减队列

1.概念

  • 队列中的元素按从大到小的顺序排列。
  • 每次插入新元素时,保证队列的元素保持递减顺序。如果新元素大于队列中的某些元素,则删除这些元素,直到新元素小于队列的尾部元素。

示例

vector<int> maxSlidingWindow(vector<int>& nums, int k) {vector<int> result;deque<int> dq;  // 单调递减队列for (int i = 0; i < nums.size(); i++) {// 移除不在窗口中的元素if (!dq.empty() && dq.front() < i - k + 1) {dq.pop_front();}// 移除队尾元素,使队列保持递减while (!dq.empty() && nums[dq.back()] <= nums[i]) {dq.pop_back();}// 加入新元素dq.push_back(i);// 队头元素是当前窗口的最大值if (i >= k - 1) {result.push_back(nums[dq.front()]);}}return result;
}

相关文章:

优先队列和单调队列(双端队列实现的)

这里写自定义目录标题 一、优先队列与单调队列二、优先队列2.1 概念2.2 增删查 判空2.3 示例代码 三、双端队列四、单调队列4.1 单调递增队列4.2 单调递减队列 一、优先队列与单调队列 二、优先队列 2.1 概念 一种特殊的队列&#xff0c;它与普通队列的主要区别在于元素的出…...

设计模式(状态模式)

概述 在实际的软件开发中&#xff0c;状态模式并不是很常用&#xff0c;但是在能够用到的场景里&#xff0c;它可以发挥很大的作用。从这一点上来看&#xff0c;它有点像我们之前讲到的组合模式。 状态模式一般用来实现状态机&#xff0c;而状态机常用在游戏、工作流引擎等系统…...

安卓基础(get和set)

在 Java 中&#xff0c;​​get 和 set​​ 方法是面向对象编程中 ​​封装&#xff08;Encapsulation&#xff09;​​ 的核心实现&#xff0c;用于安全地访问和修改类的私有字段&#xff08;private 成员变量&#xff09;。它们的核心作用是 ​​控制对数据的访问&#xff0c…...

机器人灵巧操作新突破,力感知技术让机械手更精准

在机器人的发展历程中&#xff0c;让机器人实现灵活操作一直是科研人员努力攻克的难题。 我们这篇文章给大家带来一份新的工作&#xff1a;DexForce 链接&#xff1a;[2501.10356] DexForce: Extracting Force-informed Actions from Kinesthetic Demonstrations for Dextero…...

八大排序——直接插入排序/希尔排序

八大排序——直接插入排序/希尔排序 目录 一、直接插入排序 二、希尔排序 一、直接插入排序 每一趟从待排序序列中取第一个值&#xff0c;将其插入到已排序好的序列中&#xff0c;对已排序好的序列&#xff0c;从右到左依次和待插入值比较&#xff0c;如果大于则向后挪&…...

8、HTTPD服务--ab压力测试

一、ab压力测试 # ab ‐c 100 ‐n 1000 http://vedio.linux.com/index.html 2 This is ApacheBench, Version 2.3 <$Revision: 1430300 $> 3 Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/ 4 Licensed to The Apache Software Foundation,…...

node.js 实战——mongoDB

MongoDB MongoDB 简介 MongoDB 是一种基于文档型 (document-oriented) 的 NoSQL 数据库&#xff0c;使用类 JSON 的 BSON 格式存储数据&#xff0c;自然支持复杂数据结构。它特别适合需要快速变化、大量数据处理和高应用扩展性的场景。 MongoDB 特性&#xff1a; 无法表、无…...

C语言学习路线

以下是一份综合多个优质资源的C语言学习路线规划&#xff0c;结合2025年最新技术趋势和工程实践需求&#xff0c;分为三个阶段系统推进&#xff1a; ​一、入门阶段&#xff08;1-2个月&#xff09;​​ ​目标​&#xff1a;掌握基础语法&#xff0c;能编写简单程序&#xff…...

飞凌嵌入式T527核心板获得【OpenHarmony生态产品兼容性证书】

近日&#xff0c;飞凌嵌入式FET527-C核心板通过OpenHarmony 4.1 Release版本兼容测评&#xff0c;获得【OpenHarmony生态产品兼容性证书】。 飞凌嵌入式FET527-C核心板搭载全志T527系列全国产高性能处理器&#xff0c;集成8个ARM Cortex-A55核心&#xff0c;并内置RISC-V核和DS…...

Mioty|采用报文分割(Telegram Splitting)以提高抗干扰能力的无线通信技术

1、什么是Mioty 在物联网&#xff08;IoT&#xff09;快速发展的背景下&#xff0c;低功耗广域网&#xff08;LPWAN&#xff09;技术成为连接海量设备的关键。LPWAN具有低功耗、低成本、广覆盖和强抗干扰能力等特点&#xff0c;使其特别适用于大规模、远距离、低数据速率的IoT…...

WPF 程序监控硬件设备状态变化的实现方案

以下是一个完整的 C# WPF 程序实现方案&#xff0c;用于监控硬件设备状态变化&#xff08;基于设备 SDK API&#xff09;。我们将分步骤实现&#xff0c;包含状态轮询、事件通知、UI 绑定和错误处理。 1. 项目结构设计 HardwareMonitor/ ├── Models/ # 数据模…...

利用Python打印有符号十进制数的二进制原码、反码、补码

有时候手动计算有符号十进制数的二进制原码、反码、补码是一件挺麻烦的事情。 下面是一个段Python 代码&#xff0c;它可以接收一个 16 位有符号十进制数的输入&#xff0c;然后输出其对应的二进制原码、反码和补码&#xff1a; def decimal_to_binary(decimal_num):# 检查输入…...

STM32裸机编程架构与思路

STM32作为广泛应用的微控制器系列&#xff0c;其强大的功能和灵活的编程方式使其成为嵌入式系统开发的优选。裸机编程&#xff08;bare-metal programming&#xff09;指的是在没有操作系统支持的情况下&#xff0c;直接对硬件进行编程。这种方式虽然较为底层&#xff0c;但能够…...

Eureka 深度解析:从原理到部署的全场景实践

一、Eureka 核心原理与架构设计 1. 核心定位与组件模型 Eureka 是 Netflix 开源的服务发现&#xff08;Service Discovery&#xff09;组件&#xff0c;作为 Spring Cloud 微服务体系的核心基础设施&#xff0c;其核心目标是解决分布式系统中服务实例动态管理与跨服务通信解耦…...

有哪些和PPT自动生成有关的MCP项目?

随着AI技术的快速发展, Model Context Protocol(MCP) 作为一种连接大型语言模型(LLMs)与外部工具的开放协议,正在重塑自动化办公领域。在PPT自动生成场景中,MCP通过标准化接口实现了AI模型与设计工具、数据源的无缝整合。以下从技术框架、项目案例、应用场景三个维度展开…...

经典数仓架构深度解析与演进:从离线处理到新型架构对比

经典数仓架构深度解析与演进&#xff1a;从离线处理到新型架构对比 在数据驱动决策的时代&#xff0c;经典数仓作为企业数据管理与分析的核心基础设施&#xff0c;承载着从数据存储到价值挖掘的重要使命。本文将深入剖析经典数仓的架构、数据处理流程、主流架构模式及其对比&a…...

[Python开发] 如何用 VSCode 编写和管理 Python 项目(从 PyCharm 转向)

在 Python 开发领域,PyCharm 一直是广受欢迎的 IDE,但其远程开发功能(如远程 SSH 调试)仅在付费版中提供。为了适应服务器部署需求,很多开发者开始将目光转向更加轻量、灵活且免费扩展能力强的 VSCode。本篇文章将详细介绍,从 PyCharm 转向 VSCode 后,如何高效搭建和管理…...

系统架构-架构评估

质量属性 性能 指系统的响应能力 指标&#xff1a;响应时间、吞吐量等。 设计策略&#xff1a;优先级队列、增加计算资源、减少计算开销、引入并发机制、采用资源调度 可靠性 在意外或错误使用的情况下维持软件系统的功能特性 指标&#xff1a;MTTF、MTBF、MTTR 设计策…...

使用 MQTT - C 访问 IoTDA 平台:一个完整的嵌入式示例

引言 在物联网&#xff08;IoT&#xff09;开发领域&#xff0c;设备与平台之间的通信至关重要。MQTT 作为一种轻量级的消息传输协议&#xff0c;因其高效、可靠的特性&#xff0c;在物联网场景中得到了广泛应用。华为的 IoTDA&#xff08;IoT Device Access&#xff09;平台为…...

Leetcode594.最长和谐子序列

目录 题目算法标签: 滑动窗口, 哈希表思路滑动窗口代码哈希表代码 题目 594. 最长和谐子序列 算法标签: 滑动窗口, 哈希表 思路 先将数组进行排序, 检查两个相邻的但是不相等的数字的差值是否是 1 1 1, 如果是 1 1 1更新答案 滑动窗口代码 #include <algorithm> #i…...

如何在idea中编写spark程序

在 IntelliJ IDEA 中编写 Spark 程序的详细指南 在大数据处理领域&#xff0c;Apache Spark 凭借其强大的分布式计算能力&#xff0c;成为了众多开发者的首选工具。而 IntelliJ IDEA 作为一款功能强大的集成开发环境&#xff08;IDE&#xff09;&#xff0c;为编写 Spark 程序…...

人工智能数学基础(一):人工智能与数学

在人工智能领域&#xff0c;数学是不可或缺的基石。无论是算法的设计、模型的训练还是结果的评估&#xff0c;都离不开数学的支持。接下来&#xff0c;我将带大家深入了解人工智能数学基础&#xff0c;包括微积分、线性代数、概率论、数理统计和最优化理论&#xff0c;并通过 P…...

Android Studio 安装 Continue插件

1、Android 插件Studio中安装Continue 2、从本地盘符安装 3、安装后发现Continue为空 Android studio中 Help -> Find Action->Choose Boot Java 设置 4、配置DeepSeek 参考https://juejin.cn/post/7464122534546407461...

【C++】类和对象(4)

目录 1. 类型转换 非explicit的单参数构造函数 示例 explicit的单参数构造函数 示例 不同版本的行为 示例 &#xff08;单参数&#xff09; 示例&#xff08;多参数且其余参数有默认值 &#xff09; 示例&#xff08;多参数且无默认值&#xff09; 2. static成员变量…...

微信jdk 前端vue获取流程1、

参考链接&#xff1a; 企业微信的JSSDK,调用及使用方法_企业微信jssdk-CSDN博客 1、引用 <script src"//res.wx.qq.com/open/js/jweixin-1.2.0.js"></script> <script src"https://res.wx.qq.com/open/js/jweixin-1.2.0.js" referrerpolic…...

Linux进程7-signal信号处理方式验证、可重入函数举例、信号集函数验证、信号集阻塞验证

目录 1. signal函数 1.1进程接收到信号后的处理方式 1.2 signal 函数 1.2.1 signal 函数默认处理 1.2.2 signal 函数忽略处理 1.2.3 signal 函数自定义处理 1.2.4 signal 函数返回值 2.可重入函数 2.1如何判断函数是否可重入 2.2自定义信号处理函数举例 2.2.1 sle…...

使用Python在excel里创建柱状图

一、前言 通过使用Python的openpyxl库&#xff0c;在excel里创建柱状图。openpyxl库提供了创建Excel图表的功能&#xff0c;包括柱状图(Bar Chart)。 二、程序展示 1、导入相关模块&#xff0c;新建excel 新建excel后&#xff0c;在excel的第一列创建一些数据。 import op…...

计算机视觉进化论:YOLOv12、YOLOv11与Darknet系YOLOv7的微调实战对比

摘要 YOLO系列作为实时目标检测领域的重要里程碑&#xff0c;持续引领速度与精度的平衡发展。本文围绕YOLOv7&#xff08;基于Darknet框架&#xff09;、YOLOv11及YOLOv12&#xff0c;系统、深入地对比了三款模型的架构创新、微调策略、核心技术及应用场景。我们详细解析了三者…...

湖北理元理律师事务所:债务管理领域的平台化创新探索

随着中国居民负债率攀升至62%&#xff08;央行2023年数据&#xff09;&#xff0c;债务管理从个体需求演变为社会性课题。湖北理元理律师事务所通过“法律科技金融”的融合模式&#xff0c;构建了国内首个全链条债务管理平台&#xff0c;其服务逻辑与行业价值值得深度剖析。 平…...

沐曦玩转 LMDeploy、XTuner 和 InternLM3

学习链接&#xff1a; https://aicarrier.feishu.cn/wiki/O84LwkiBriUU0NkDwurcSufhnVb 一 LMDeploy推理及验证 1.1 下载LMDeploy # 安装addict软件包 pip install addict mmengine mmengine-lite fire accelerate0.32.1 nvidia-ml-py# 解决LMDeploy对tranformers版本要求的…...

【Java面试笔记:进阶】26.如何监控和诊断JVM堆内和堆外内存使用?

监控和诊断JVM内存使用是优化性能和解决内存问题的关键。 1.JVM内存监控与诊断方法 1.图形化工具 JConsole:提供图形化界面,可直接连接到Java进程,查看内存使用情况。VisualVM:功能强大的图形化工具,但注意从Oracle JDK 9开始不再包含在JDK安装包中。Java Mission Contr…...

阿里云服务器云盘扩容

在阿里云服务器上在线扩容了云盘后&#xff0c;如果服务器内部查看容量没有变化&#xff0c;可能是由于分区和文件系统未正确扩展。以下是详细的解决步骤&#xff1a; 1. 确认扩容是否成功 在阿里云控制台检查磁盘容量是否已显示扩容后的新大小。如果控制台显示已扩容&#x…...

【ESP32】st7735s + LVGL移植

LVGL的移植 使用版本1、创建工程2、开始移植2.1、文件准备2.2、修改代码2.3、SDK配置编辑器 3、测试 使用版本 LVGL版本&#xff1a;8.3 链接点这里ESPIDF版本&#xff1a;4.4.8lvgl_esp32_drivers&#xff1a; 链接点这里ESP32型号&#xff1a;ESP32S3 1、创建工程 默认都会…...

Jackson 使用方法详解

Jackson 是 Java 生态中最流行的 JSON 处理库&#xff0c;也是 Spring Boot 的默认 JSON 解析器。它提供了高性能的 JSON 序列化&#xff08;对象 → JSON&#xff09;和反序列化&#xff08;JSON → 对象&#xff09;功能。以下是 Jackson 的全面使用指南。 1. 基础依赖 Mave…...

TensorFlow深度学习框架:从入门到精通的完整指南

&#x1f31f; TensorFlow核心优势 TensorFlow作为Google开发的顶级深度学习框架&#xff0c;具有三大独特优势&#xff1a; 工业级部署能力&#xff1a;支持从移动端到服务器的全平台部署完善的工具链&#xff1a;包含TensorBoard、TF Lite、TF.js等完整生态强大的社区支持&…...

Java 入门宝典--注释、关键字、数据类型、变量常量、类型转换

作者&#xff1a;IvanCodes 发布时间&#xff1a;2025年4月28日&#x1f423; 专栏&#xff1a;Java教程 哈喽&#xff0c;各位 CSDN 的小伙伴们&#xff01;&#x1f44b; 这部分内容虽然基础&#xff0c;但 极其重要&#xff0c;是后续学习所有高级特性的基石。准备好了吗&…...

【含文档+PPT+源码】基于微信小程序的旅游论坛系统的设计与实现

项目介绍 本课程演示的是一款基于微信小程序的旅游论坛系统的设计与实现&#xff0c;主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的 Java 学习者。 1.包含&#xff1a;项目源码、项目文档、数据库脚本、软件工具等所有资料 2.带你从零开始部署运行本套系统 …...

Android开发,实现一个简约又好看的登录页

文章目录 1. 编写布局文件2.设计要点说明3. 效果图4. 关于作者其它项目视频教程介绍 1. 编写布局文件 编写activity.login.xml 布局文件 <?xml version"1.0" encoding"utf-8"?> <androidx.appcompat.widget.LinearLayoutCompat xmlns:android…...

一种改进的YOLOv11网络,用于无人机视角下的小目标检测

大家读完觉得有帮助记得关注和点赞&#xff01;&#xff01;&#xff01; 摘要 随着无人机&#xff08;UAV&#xff09;和计算机视觉技术的快速发展&#xff0c;从无人机视角进行目标检测已成为一个重要的研究领域。然而&#xff0c;无人机图像中目标像素占比极小、物体尺度变…...

linux离线安装zsh

下载zsh 下载仓库后解压 下载地址&#xff1a;https://github.com/zsh-users/zsh 离线安装 安装方法见INSTALL文件 ./configure --prefix[/usr/local] make make install...

Golang|使用函数作为参数和使用接口的联系

函数作为数据类型的一种&#xff0c;可以成为其他函数的参数。在 Go&#xff08;Golang&#xff09; 中&#xff0c;函数作为参数 和 接口&#xff08;interface&#xff09;&#xff0c;本质上都和抽象、灵活调用有关 —— 都是让代码更灵活、更可扩展的手段。不过它们各有侧重…...

Python爬虫实战:获取软科网最新特定专业大学排名数据并做分析,为高考填报志愿做参考

一、引言 在高考升学的重要阶段,志愿填报成为考生和家长关注的核心问题。准确、全面且具有权威性的大学专业排名数据,是考生做出科学志愿决策的关键依据。软科网作为专业的大学排名信息发布平台,其发布的计算机科学与技术专业排名数据,因具有较高的公信力和参考价值,备受…...

【ACL系列论文写作指北12-Deadline管理与科研项目规划】-用节奏赢得高质量科研

科研不是一场冲刺&#xff0c;而是有序推进的系统工程。 引言&#xff1a;掌控时间&#xff0c;才能掌控科研主动权 再好的想法和技术&#xff0c;如果没有良好的时间管理&#xff0c;最终只会沦为“赶DDL”的牺牲品。科研项目规划&#xff0c;是确保质量、效率与心态平衡的关…...

elasticsearch底层模块解析与实践系列

#作者&#xff1a;猎人 文章目录 底层模块深入解析之threadpool1、线程池2、线程池类型3、cpu core数量设置 底层模块深入解析之plugin底层模块深入解析之es node节点角色1、node类型2、master eligible node3、data node4、ingest node5、cooridnating only node6、node data…...

Git-基本操作

前言 安装 git --version sudo apt-get remove git -y #卸载 sudo apt-get install git -y基本操作 创建本地仓库 mkdir gitcodegit init 这个就可以创建本地仓库了 然后当前目录下就有一个.git的文件夹 配置本地仓库 就是配置用户的名称&#xff0c;和用户的email地址 在…...

iVX 图形化编程如何改写后端开发新范式

在数字化转型加速推进的当下&#xff0c;企业对后端系统的需求呈现爆发式增长。Gartner 最新报告指出&#xff0c;2025 年全球企业平均需完成 300 定制化应用开发&#xff0c;而传统编码模式下&#xff0c;单个项目平均交付周期长达 6 - 8 个月。与此同时&#xff0c;Redis、K…...

【数据可视化-42】杂货库存数据集可视化分析

&#x1f9d1; 博主简介&#xff1a;曾任某智慧城市类企业算法总监&#xff0c;目前在美国市场的物流公司从事高级算法工程师一职&#xff0c;深耕人工智能领域&#xff0c;精通python数据挖掘、可视化、机器学习等&#xff0c;发表过AI相关的专利并多次在AI类比赛中获奖。CSDN…...

使用 Electron 打包 Windows 可执行程序

使用 Electron 打包 Windows 可执行程序 在使用 Electron 构建桌面应用程序时&#xff0c;通常需要将项目打包为可执行文件&#xff08;例如 .exe 文件&#xff09;&#xff0c;以便用户可以方便地安装和运行。本文将介绍如何使用 electron-builder 将 Electron 项目打包成 Wi…...

爬虫学习笔记(三)--Http协议

思维导图 上面思维导图提取的原文是2026王道计网P286~290 URL最前面&#xff08;URL传输过程中遵循HTTP协议&#xff09; 协议 计算机传输的数据实际上就是二进制0和1&#xff0c;协议就是规定这一串二进制数字的前几位代表什么、中间几位代表什么、后几位代表什么 HTTP&a…...

ai环境cuda cudnn conda torch整体迁移 wsl docker

运行没问题的环境&#xff0c;wsl先关停wsl --shutdown 然后导出复制到迁移机器上wsl --export U24 E:\wsl\u24.tar 使用wsl版挂成虚拟机wsl --import U24 E:\wsl\ubuntu E:\wsl\u24.tar 使用docker版挂成镜像docker import E:\wsl\u24.tar my-ubuntu:custom 启动docker容器&am…...