POJ-2823-Sliding Window

本文介绍了一种使用单调队列解决滑动窗口最大值与最小值问题的方法。通过具体实例代码展示了如何利用单调队列进行高效计算,包括初始化队列、更新队列元素及获取窗口内最大最小值的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本来想看一个题的解题报告,无意中搜索到这个题,因为这个题主要是单调队列,所以就做了。

关于单调队列请看:http://www.felix021.com/blog/read.php?1965

最后再参考了这位大牛的博客:http://blog.youkuaiyun.com/hyogahyoga/article/details/7829830

然后基本懂了,主要是觉得这位大牛实现得比较简单,膜拜~

直接代码吧:


#include<cstdio>
#include<cstring>
#define MAX 1000001
int n,k,a[MAX],q[MAX];
void GetMin()
{
    int front=1,last=q[1]=1;
    for(int i=1;i<=n;i++)
    {
	if(front<=last&&q[front]<i-k+1)
	    front++;
	while(front<=last&&a[i]<=a[q[last]])
	    last--;
	q[++last]=i;
	if(i>=k)
	    printf("%d%c",a[q[front]],i==n?'\n':' ');
    }
}
void GetMax()
{
    int front=1,last=q[1]=1;
    for(int i=1;i<=n;i++)
    {
	if(front<=last&&q[front]<i-k+1)
	    front++;
	while(front<=last&&a[i]>=a[q[last]])
	    last--;
	q[++last]=i;
	if(i>=k)
	    printf("%d%c",a[q[front]],i==n?'\n':' ');
    }
}
int main()
{
    while(scanf("%d%d",&n,&k)!=EOF)
    {
	for(int i=1;i<=n;i++)
	    scanf("%d",&a[i]);
	GetMin();
	GetMax();
    }
    return 0;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值