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

算法提升之单调数据结构-(单调队列)

继昨天跟大家分享了有关单调栈的内容,今天将给大家分享的是有关单调队列的有关内容,可以发现单调队列常用来处理的是某一个区间内的最大与最小值。

单调队列的核心作用

在这个问题中,我们需要处理长度为k的滑动窗口,对每个窗口求最大值和最小值。单调队列的作用是在 O (n) 时间复杂度内完成所有窗口的最大 / 最小值计算,比暴力法(O (nk))高效得多。

代码中的两个单调队列

  1. qmax:维护当前窗口中最大值的单调递减队列
  2. qmin:维护当前窗口中最小值的单调递增队列

问题描述

熊大和熊二在玩游戏。他们将 n 个正整数 a1​,a2​,...,an​ 排成一行,然后各用一个长度为 k 的框在这个数组中各自随机框选出一段长度为 k 的连续子序列(随机框选指在合法的 n−k+1 个连续子序列中均匀随机)。熊大记录了他框出的 k 个数中的最大值 P,熊二记录了他框出的 k个数的最小值 Q,他们突然有个疑问:P−Q的期望是多少?

2024-11-27 Update:Java 时限调整至 1s

输入描述

输入共 2 行。

第一行为两个正整数 n,k

第二行为 n 个由空格隔开的正整数a1​,a2​,...,an​。

输出描述

输出共 1 行,一个浮点数(请保留两位小数)。

输入案例:

3 2
1 2 3

输出案例:

1.00

代码部分:

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
int n, k;
int main()
{cin >> n >> k;vector<int> a(n);for (int i = 0; i < n; ++i){cin >> a[i];}deque<int> qmax, qmin;LL ans = 0;for (int i = 0; i < n; ++i){if (qmax.size() && qmax.front() < i - k + 1)qmax.pop_front();if (qmin.size() && qmin.front() < i - k + 1)qmin.pop_front();while (qmax.size() && a[qmax.back()] < a[i])qmax.pop_back();while (qmin.size() && a[qmin.back()] > a[i])qmin.pop_back();qmax.push_back(i);qmin.push_back(i);if (i >= k - 1)ans += a[qmax.front()] - a[qmin.front()];}double res = 1.0*ans / (n - k + 1);printf("%.2f",res);return 0;
}

注意点⚠️:

if (qmax.size() && qmax.front() < i - k + 1)qmax.pop_front();
if (qmin.size() && qmin.front() < i - k + 1)qmin.pop_front();
  1. 这部分确保队列头部元素在当前窗口范围内([i-k+1, i]),如果超出范围则移除

2.维护单调队列特性

// 维护递减队列(最大值)
while (qmax.size() && a[qmax.back()] < a[i])qmax.pop_back();// 维护递增队列(最小值)
while (qmin.size() && a[qmin.back()] > a[i])qmin.pop_back();

3.添加新元素并计算结果

qmax.push_back(i);
qmin.push_back(i);if (i >= k - 1)  // 窗口大小达到k时开始计算ans += a[qmax.front()] - a[qmin.front()];

要注意单调栈和单调队列其实都是有自身的局限性的,但是对于处理固定数组下的特定区间问题往往会比暴力法更快,会比其他方法更简单,对于一些算法题可以起到出其不意的效果。

http://www.dtcms.com/a/398257.html

相关文章:

  • PHP 线上环境 Composer 依赖包更新部署指南-简易版
  • 设计模式-原型模式详解
  • ESP8266与CEM5826-M11毫米波雷达传感器的动态检测系统
  • [原创]怎么用qq邮箱订阅arxiv.org?
  • 设计模式-中介者模式详解
  • 【探寻C++之旅】第十四章:简单实现set和map
  • 牛客:机器翻译
  • 20250925的学习笔记
  • 域名不同网站程序相同wordpress多门户网站
  • 淘宝API商品详情接口全解析:从基础数据到深度挖掘
  • 【低代码】百度开源amis
  • 求推荐专业的网站建设开发免费商城
  • java面试day4 | 微服务、Spring Cloud、注册中心、负载均衡、CAP、BASE、分布式接口幂等性、xxl-job
  • 高QE sCMOS相机在SIM超分辨显微成像中的应用
  • C++设计模式之创建型模式:原型模式(Prototype)
  • Node.js/Python 调用 1688 API 实时拉取商品信息的实现方案
  • OpenLayers地图交互 -- 章节九:拖拽框交互详解
  • 浅谈 Kubernetes 微服务部署架构
  • 媒体资源云优客seo排名公司
  • 企业如何构建全面防护体系,应对勒索病毒与恶意软件攻击?
  • 【重磅发布】《特色产业数据要素价值化研究报告》
  • fast-lio有ros2版本吗?
  • PWM 冻结模式 模式1 强制输出有效电平 强制输出无效电平 设置有效电平 实现闪烁灯
  • 系统分析师-软件工程-信息系统开发方法面向对象原型化方法面向服务快速应用开发
  • Linux的写作日记:Linux基础开发工具(一)
  • 做响应网站的素材网站有哪些怎么在年报网站做简易注销
  • C++中的initializer_list
  • 关于营销型网站建设的建议促进房地产市场健康发展
  • PHP验证码生成与测试
  • 漫谈<无头浏览器技术>:二、演进之路