P3594 [POI2015]WIL-Wilcze do?y
Posted sfwr-you
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了P3594 [POI2015]WIL-Wilcze do?y相关的知识,希望对你有一定的参考价值。
————————————————————————————————————————————————————
修改一次的单调队列,借助单调队列求出区间内删除达到的最大值,再借助连续增长的l,r求解,挺好的题
——————————————————————————————————————————————————
#include<bits/stdc++.h> using namespace std; long long a[2000005],n,p,d,sum[2000005],q[2000005],last=1,hd,tl,t[2000005],ans; int main() cin>>n>>p>>d; for(int i=1;i<=n;i++)cin>>a[i];sum[i]=sum[i-1]+a[i]; for(int i=d;i<=n;i++)t[i]=sum[i]-sum[i-d]; ans=d;q[++tl]=d; for(int i=d+1;i<=n;i++) while(hd<=tl&&t[q[tl]]<t[i])tl--; q[++tl]=i; while(hd<=tl&&q[hd]-d+1<last)hd++; while(hd<=tl&&sum[i]-sum[last-1]-t[q[hd]]>p) last++; while(hd<=tl&&q[hd]-d+1<last)hd++; ans=max(i-last+1,ans); cout<<ans;
以上是关于P3594 [POI2015]WIL-Wilcze do?y的主要内容,如果未能解决你的问题,请参考以下文章