滑动窗口(C++)

样例输入

复制代码
8 3
1 3 -1 -3 5 3 6 7

样例输出

复制代码
-1 -3 -3 -3 3 3
3 3 5 5 6 7

数据范围

对于 20% 的数据,K≤N≤1000;

对于 50% 的数据,K≤N≤10^5;

对于 100% 的数据,K≤N≤10^6。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

int a[1000006];

void yjc(int n, int w) {
	deque<int> q;
	for (int i = 0; i < n; ++i) {
		while (!q.empty() && a[q.back()] <= a[i]) {
			q.pop_back();
		}
		q.push_back(i);
		if (i >= w - 1) {
			cout << a[q.front()] << ' ';
			if (q.front() == i - w + 1) {
				q.pop_front();
			}
		}
	}
	cout << endl;
}

void xzh(int n, int w) {
	deque<int> q;
	for (int i = 0; i < n; ++i) {
		while (!q.empty() && a[q.back()] >= a[i]) {
			q.pop_back();
		}
		q.push_back(i);
		if (i >= w - 1) {
			cout << a[q.front()] << ' ';
			if (q.front() == i - w + 1) {
				q.pop_front();
			}
		}
	}
	cout << endl;
}

int main() {
	int n, w;
	cin >> n >> w;
	for (int i = 0; i < n; ++i) {
		cin >> a[i];
	}

	xzh(n, w);
	yjc(n, w);

	return 0;
}
相关推荐
hyl2001220 小时前
使用C++库GNU Scientific Library求解非线性方程(组)
开发语言·c++
凤年徐20 小时前
优选算法——滑动窗口2
数据结构·c++·算法
历程里程碑20 小时前
37 线程安全单例模式深度解析
java·服务器·开发语言·前端·javascript·c++·排序算法
ambition2024220 小时前
蓝桥杯“水质检测“问题:0-1 BFS算法的完整解析
c语言·数据结构·c++·算法·蓝桥杯·宽度优先
云深麋鹿20 小时前
C++ | 手搓一个string类
开发语言·c++·容器
刺客xs20 小时前
C++ 11新特性
java·开发语言·c++
..过云雨20 小时前
【负载均衡oj项目】04. oj_server题目信息获取、界面渲染、负载均衡、后台交互功能
运维·c++·html·负载均衡·交互
..过云雨20 小时前
【负载均衡oj项目】02. comm公共文件夹设计 - 包含所有需要用到的自定义工具
数据库·c++·mysql·html·负载均衡
知无不研20 小时前
constexpr关键字
开发语言·c++·constexpr
2401_8980751220 小时前
C++中的智能指针详解
开发语言·c++·算法