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

BZOJ 1699 [Usaco2007 Jan]Balanced Lineup排队 线段树

时间:2015-08-18 22:49:03      阅读:134      评论:0      收藏:0      [点我收藏+]

标签:

题意:链接

方法:线段树

解析:

题意即题解。

多次询问区间最大值与最小值的差,显然直接上线段树或者rmq维护区间最值即可。

代码:

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#define N 50010
#define lson l,mid,rt<<1
#define rson mid+1,r,rt<<1|1
#define pa pair<int,int>
using namespace std;
int n,q;
int ma[N<<2],mi[N<<2],dis[N<<2];
void init()
{
    memset(ma,-1,sizeof(ma));
    memset(mi,0x3f,sizeof(mi));
}
void pushup(int rt)
{
    ma[rt]=max(ma[rt<<1],ma[rt<<1|1]);
    mi[rt]=min(mi[rt<<1],mi[rt<<1|1]);
}
void build(int l,int r,int rt)
{
    if(l==r)
    {
        int x;
        scanf("%d",&x);
        ma[rt]=mi[rt]=x;
        return;
    }
    int mid=(l+r)>>1;
    build(lson),build(rson);
    pushup(rt);
}
pa query(int L,int R,int l,int r,int rt)
{
    pa ret;
    ret.first=-1,ret.second=0x3f3f3f3f;
    if(L<=l&&r<=R)
    {
        pa p;
        p.first=ma[rt],p.second=mi[rt];
        return p;
    }
    int mid=(l+r)>>1;
    if(L<=mid)
    {
        pa tmp=query(L,R,lson);
        ret.first=max(ret.first,tmp.first),ret.second=min(ret.second,tmp.second);
    }
    if(R>mid)
    {
        pa tmp=query(L,R,rson);
        ret.first=max(ret.first,tmp.first),ret.second=min(ret.second,tmp.second);
    }
    return ret;
}
int main()
{
    init();
    scanf("%d%d",&n,&q);
    build(1,n,1);
    for(int i=1;i<=q;i++)
    {
        int x,y;
        scanf("%d%d",&x,&y);
        pa tmp=query(x,y,1,n,1);
        printf("%d\n",tmp.first-tmp.second);
    }
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

BZOJ 1699 [Usaco2007 Jan]Balanced Lineup排队 线段树

标签:

原文地址:http://blog.csdn.net/wzq_qwq/article/details/47760633

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