POJ-2823-Sliding Window

378 篇文章 0 订阅
21 篇文章 0 订阅

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

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

最后再参考了这位大牛的博客:http://blog.csdn.net/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;
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值