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;
}
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;
}
相关文章推荐
- HDU 3415 Max Sum of Max-K-sub-sequence[单调队列优化dp]
- 【单调队列】hdu 3415 Max Sum of Max-K-sub-sequence
- 单调队列——HDU 3415 Max Sum of Max-K-sub-sequence
- hdu 3415 单调队列1
- hdu 3415 Max Sum of Max-K-sub-sequence 单调队列 求连续l(1<=l<=k)个数的和的最大值 数列可循环
- HDU 3415 Max Sum of Max-K-sub-sequence[单调队列优化dp]
- HDU--3415--Max Sum of Max-K-sub-sequence--单调队列
- hdu 3415 Max Sum of Max-K-sub-sequence(单调队列)
- HDU 3415单调队列
- hdu 3415 单调队列
- HDU 3415 (单调队列优化DP)
- HDU 3415 单调队列
- hdu 3415 Max Sum of Max-K-sub-sequence 单调队列dp
- hdu 3415 Max Sum of Max-K-sub-sequence(单调队列)
- HDU-3415 Max Sum of Max-K-sub-sequence 单调队列
- hdu 3415 Max Sum of Max-K-sub-sequence【单调队列】
- HDU 3415(Max Sum of Max-K-sub-sequence-单调队列优化DP)
- hdu 3415 Max Sum of Max-K-sub-sequence 单调队列dp
- HDU 3415 Max Sum of Max-K-sub-sequence(单调队列)
- [ACM] hdu 3415 Max Sum of Max-K-sub-sequence (单调队列)