您的位置:首页 > 编程语言 > Go语言

hdu 3415 单调队列

2014-07-17 01:01 183 查看
母题的变形啊

   window[x,x+k]

现在要求的是一段的sum的大小 那么我们只要预先处理出前缀的和就行了   

手动实现的话真的是有点累的 学了一下别人的stl --deque

250ms、、这就是时间的代价

不过要注意 deque的front() 和back()返回的真的是 int啊  从1开始的

#include<stdio.h>
#include<cstdio>
#include<iostream>
#include<deque>
using namespace std;
#define maxn 111111
#define inf 99999999
int a[maxn],sum[maxn];

int main(){
deque<int>q;
int n,k,_;scanf("%d",&_);
int ans,head=0,end=0;
while(_--){
ans=-inf;
scanf("%d%d",&n,&k);
int _n=n;
sum[0]=0;
for(int i=1;i<=n;++i){
scanf("%d",&a[i]);
sum[i]=a[i]+sum[i-1];
}
for(int i=n+1;i<n+k;++i)
sum[i]=sum[i-1]+a[i-n];
n=n+k-1;
q.clear();
for(int i=1;i<=n;++i){
while(!q.empty()&&sum[i-1]<sum[q.back()])q.pop_back();
while(!q.empty()&&q.front()<i-k)q.pop_front();
q.push_back(i-1);
if(sum[i]-sum[q.front()]>ans){
ans=sum[i]-sum[q.front()];
head=q.front()+1;
end=i;
}
}
if(end>_n)end%=_n;
printf("%d %d %d\n",ans,head,end);

}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  algorithm