0

0

c++中如何实现单调队列_c++单调队列实现方法

穿越時空

穿越時空

发布时间:2025-10-13 20:00:01

|

1010人浏览过

|

来源于php中文网

原创

单调队列是双端队列,维护元素下标对应的值单调递减或递增,用于滑动窗口最值问题。1. 用std::deque存储下标,便于判断是否过期;2. 插入前从队尾删除小于当前值的下标,保持单调性;3. 队首超出窗口时移除;4. 从第k个元素开始记录结果。时间复杂度O(n),优于暴力法。

c++中如何实现单调队列_c++单调队列实现方法

在C++中,单调队列通常用于解决滑动窗口类问题,比如求滑动窗口最大值、最小值,或满足某种单调性要求的子数组问题。单调队列的核心思想是维护一个队列,使得其中的元素在值上保持单调递增或递减,同时保证下标顺序。

什么是单调队列

单调队列是一种双端队列(deque),它从队首到队尾的元素值保持单调性(递增或递减)。常见的是单调递减队列用于求最大值,单调递增队列用于求最小值。关键在于:每当我们加入一个新元素时,从队尾开始删除所有“不再有希望成为答案”的元素。

使用std::deque实现单调队列

我们可以借助C++标准库中的std::deque来高效实现单调队列。以下是一个求滑动窗口最大值的典型例子:

示例:滑动窗口最大值

立即学习C++免费学习笔记(深入)”;

给定一个数组 nums 和窗口大小 k,输出每个窗口内的最大值。

笔灵AI论文写作
笔灵AI论文写作

免费生成毕业论文、课题论文、千字大纲,几万字专业初稿!

下载
#include 
#include 
using namespace std;

vector maxSlidingWindow(vector& nums, int k) {
    deque dq;  // 存储数组下标,保证对应值单调递减
    vector result;

    for (int i = 0; i < nums.size(); ++i) {
        // 移除超出窗口范围的下标(队首)
        if (!dq.empty() && dq.front() == i - k)
            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;
}

关键操作说明

上述代码的关键点如下:

  • 存储下标而非值:便于判断元素是否还在窗口内。
  • 维护单调性:每次插入前,从队尾删除所有对应值小于当前值的下标,确保队列单调递减。
  • 处理过期元素:当队首下标超出窗口左边界时,将其弹出。
  • 结果收集时机:从第k个元素开始(即 i >= k-1),每个位置都可以输出一个窗口最大值。

扩展:单调递增队列(求最小值)

如果要维护单调递增队列以获取窗口最小值,只需修改比较条件:

```cpp while (!dq.empty() && nums[dq.back()] > nums[i]) dq.pop_back(); ```

其余逻辑保持一致。

基本上就这些。掌握单调队列的关键是理解“用空间换优势”——通过维护一个结构,把O(nk)暴力优化到O(n)。核心是双端队列的操作和单调性的维护。不复杂但容易忽略细节。

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

82

2023.09.25

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

203

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

111

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

124

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

93

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

663

2025.12.31

html5怎么播放视频
html5怎么播放视频

想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。

19

2025.12.31

关闭win10系统自动更新教程大全
关闭win10系统自动更新教程大全

本专题整合了关闭win10系统自动更新教程大全,阅读专题下面的文章了解更多详细内容。

15

2025.12.31

阻止电脑自动安装软件教程
阻止电脑自动安装软件教程

本专题整合了阻止电脑自动安装软件教程,阅读专题下面的文章了解更多详细教程。

6

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 5.9万人学习

C 教程
C 教程

共75课时 | 3.8万人学习

C++教程
C++教程

共115课时 | 10.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号