码迷,mamicode.com
首页 > 其他好文 > 详细

HDU_3415_单调队列

时间:2016-09-30 07:35:21      阅读:142      评论:0      收藏:0      [点我收藏+]

标签:

http://acm.hdu.edu.cn/showproblem.php?pid=3415

 

初探单调队列,需要注意的是每次i维护的是i-1。

 

#include<iostream>
#include<cstring>
#include<cstdio>
#include<deque>
#define INF 0x3f3f3f3f
using namespace std;
int a[200005],sum[200005];
deque<int> q;
int main()
{
    int T,n,k;
    scanf("%d",&T);
    while(T--)
    {
        q.clear();
        sum[0] = 0;
        scanf("%d%d",&n,&k);
        for(int i = 1;i <= n;i++)
        {
            scanf("%d",&a[i]);
            sum[i] = sum[i-1]+a[i];
        }
        for(int i = 1;i < n;i++)    sum[i+n] = sum[i+n-1]+a[i];
        int ans = -INF,left,right;
        int endd = 2*n;
        for(int i = 1;i < endd;i++)
        {
            while(!q.empty() && sum[i-1] < sum[q.back()])   q.pop_back();
            if(!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()];
                left = q.front()+1;
                right = i;
            }
        }
        if(right > n)   right -= n;
        printf("%d %d %d\n",ans,left,right);
    }
    return 0;
}

 

HDU_3415_单调队列

标签:

原文地址:http://www.cnblogs.com/zhurb/p/5922484.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!