0

0

c++中如何实现滑动窗口最大值_c++滑动窗口最大值实现方法

穿越時空

穿越時空

发布时间:2025-10-13 21:56:01

|

577人浏览过

|

来源于php中文网

原创

使用双端队列可在O(n)时间解决滑动窗口最大值问题:遍历数组,维护存储下标的deque,确保队首为当前窗口最大值下标,通过弹出过期和较小值元素保持单调性,窗口形成后记录结果。

c++中如何实现滑动窗口最大值_c++滑动窗口最大值实现方法

在C++中实现滑动窗口最大值,最高效的方法是使用双端队列(deque)来维护窗口内可能成为最大值的元素索引。这种方法可以在O(n)时间复杂度内解决该问题,避免对每个窗口都进行重复遍历。

使用双端队列实现滑动窗口最大值

核心思想是:用一个deque保存当前窗口中元素的下标,且保证队首始终是当前窗口最大值的下标。为了维持这一性质,需要按以下规则操作:

  • 遍历数组时,如果队列非空且队首元素已滑出窗口范围(即下标小于 i - k + 1),将其从队首弹出
  • 在将当前元素下标加入队列前,从队尾开始删除所有对应值小于等于当前元素值的下标,因为这些元素不可能再成为后续窗口的最大值
  • 将当前下标加入队尾
  • 当遍历到第k个元素及之后时,队首就是当前窗口最大值,记录结果

// 示例代码

include

include

using namespace std;

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

vector maxSlidingWindow(vector& nums, int k) { deque dq; vector result;

for (int i = 0; i zuojiankuohaophpcn nums.size(); ++i) {
    // 移除超出窗口范围的索引
    if (!dq.empty() && dq.front() zuojiankuohaophpcn= i - k)
        dq.pop_front();

    // 从队尾移除小于等于当前值的元素索引
    while (!dq.empty() && nums[dq.back()] zuojiankuohaophpcn= nums[i])
        dq.pop_back();

    // 当前索引入队
    dq.push_back(i);

    // 窗口形成后开始记录最大值
    if (i youjiankuohaophpcn= k - 1)
        result.push_back(nums[dq.front()]);
}

return result;

}

OmniAudio
OmniAudio

OmniAudio 是一款通过 AI 支持将网页、Word 文档、Gmail 内容、文本片段、视频音频文件都转换为音频播客,并生成可在常见 Podcast ap

下载

算法关键点说明

双端队列中存储的是下标而非数值,这样可以同时判断位置和取值。队列中的元素按对应数值单调递减排列,因此称为“单调队列”结构。这种设计确保了每次获取最大值的操作都是O(1)。

时间复杂度为O(n),每个元素最多入队和出队一次;空间复杂度为O(k),队列中最多保留k个元素。

边界情况处理

需要注意输入数组为空或k为0的情况,在函数开始处添加判空逻辑更健壮:

if (nums.empty() || k == 0) return {};

基本上就这些。使用deque实现的滑动窗口最大值方法高效且易于理解,适合在实际编程中直接应用。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

731

2023.08.22

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

534

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

51

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

194

2025.08.29

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

399

2023.08.14

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

78

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

45

2026.01.09

学python好用的网站推荐
学python好用的网站推荐

本专题整合了python学习教程汇总,阅读专题下面的文章了解更多详细内容。

118

2026.01.09

热门下载

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

精品课程

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

共94课时 | 6.5万人学习

C 教程
C 教程

共75课时 | 4万人学习

C++教程
C++教程

共115课时 | 11.9万人学习

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

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