单调队列

luogu P1886 滑动窗口 https://www.luogu.org/problemnew/show/P1886

 1 // luogu-judger-enable-o2
 2 #include<bits/stdc++.h>
 3 using namespace std;
 4 #define il inline
 5 #define rg register
 6 typedef long long ll;
 7 #define max(a,b) (a)<(b)?(b):(a)
 8 #define gmax(a,b) a=max(a,b)
 9 #define min(a,b) (a)<(b)?(a):(b)
10 #define gmin(a,b) a=min(a,b)
11 #define FOR(i,a,b) for(rg int i=a;i<=b;++i)
12 #define For(i,a,b) for(rg int i=a;i>=b;--i)
13 #define gc pa==pb&&(pb=(pa=buf)+fread(buf,1,100000,stdin),pa==pb)?EOF:*pa++
14 static char buf[100000],*pa(buf),*pb(buf);
15 il int rd(){
16     rg int x(0),w(1);
17     rg char c(gc);
18     while(c<'0'||c>'9')
19     {
20         if(c=='-') w=-1;
21         c=gc;
22     }
23     while(c>='0'&&c<='9') x=x*10+c-48,c=gc;
24     return x*w;}
25 const int N=1e6+5;
26 int q[N],hd,tl;
27 int n,k,a[N],ans;
28 
29 int main()
30 {
31     n=rd(),k=rd();
32     FOR(i,1,n) a[i]=rd();
33     hd=tl=1;ans=1e9;
34     FOR(i,1,k-1) 
35     {
36         while(hd<=tl && a[q[tl]]>=a[i]) --tl;
37         q[++tl]=i;
38     }
39     FOR(i,k,n)
40     {
41         while(hd<=tl && q[hd]<=i-k) ++hd;
42         while(hd<=tl && a[q[tl]]>=a[i]) --tl;
43         q[++tl]=i;
44         printf("%d ",a[q[hd]]);
45     }
46     printf("\n");
47     hd=tl=1;ans=-(1e9);
48     FOR(i,1,k-1)
49     {
50         while(hd<=tl && a[q[tl]]<=a[i]) --tl;
51         q[++tl]=i;
52     }
53     FOR(i,k,n)
54     {
55         while(hd<=tl && q[hd]<=i-k) ++hd;
56         while(hd<=tl && a[q[tl]]<=a[i]) --tl;
57         q[++tl]=i;
58         printf("%d ",a[q[hd]]);
59     }
60     return 0;
61 }

 

转载于:https://www.cnblogs.com/universeplayer/p/10742529.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
Python的单调队列是一种用于解决某些特定问题的数据结构。它是队列的一种变体,可以快速查询当前队列中的最大或最小元素。 单调队列通常用于需要维护当前滑动窗口中的最大或最小值的情况。例如,假设我们有一个长度为n的数组arr和一个窗口大小为k的滑动窗口。我们想要找到每个窗口中的最大值。单调队列就可以帮助我们在O(n)的时间复杂度内实现。 实现单调队列需要两个操作:push(x)和pop()。push(x)用于向队列的尾部添加元素x,而pop()用于从队列的头部删除元素。这两个操作具有O(1)的时间复杂度。 当我们向队列中添加一个新元素时,为了维护队列的单调性,我们需要从队列的尾部删除一些元素。具体来说,我们从队列的尾部开始,不断地删除比新元素小的元素,直到队列为空或者新元素大于等于队列尾部元素为止。这样,我们就可以保证队列中的元素是以递减顺序排列的。 当我们需要查询当前队列中的最大或最小值时,只需访问队列头部的元素即可。由于队列中的元素是以递减的顺序排列的,所以头部元素就是最大值(或最小值)。 总的来说,Python的单调队列是一种高效的数据结构,可以用于解决一些特定问题,如滑动窗口中的最大(或最小)值。它具有O(n)的时间复杂度,并且可以通过push(x)和pop()操作来维护队列的单调性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值