poj3264(线段树求区间最大最小值)

原创 2013年12月05日 09:00:32

题目链接:poj3264

简单题,求区间最大值和最小值

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define N 1000010
int n,a[N];
int ans_x, ans_y;
struct node
{
    int r,l;
    int maxx,minn;
}s[N<<2];
void build(int l, int r, int n)
{
    s[n].l = l;
    s[n].r = r;
    s[n].maxx = 0;
    s[n].minn = N;
    if(l == r)
    {
        s[n].maxx = s[n].minn = a[l];
        return;
    }
    int mid = (l + r) >> 1;
    build(l, mid, n<<1);
    build(mid + 1, r, n<<1|1);
    s[n].maxx = max(s[n<<1].maxx, s[n<<1|1].maxx);
    s[n].minn = min(s[n<<1].minn, s[n<<1|1].minn);
}
void query(int l, int r, int n)
{
    if(s[n].l == l && s[n].r == r)
    {
        ans_x = max(ans_x, s[n].maxx);
        ans_y = min(ans_y, s[n].minn);
        return;
    }
    int mid = (s[n].l + s[n].r) >> 1;
    if(r <= mid)
        query(l, r, n<<1);
    else if(l > mid)
        query(l, r, n<<1|1);
    else
    {
        query(l, mid, n<<1);
        query(mid+1, r, n<<1|1);
    }
}
int main()
{
    int m,t,i,x,y;
    while(~scanf("%d%d",&m,&t))
    {
        for(i = 1; i <= m; i ++)
            scanf("%d",&a[i]);
        build(1,m,1);
        while(t--)
        {
            scanf("%d%d",&x,&y);
            ans_x = 0;
            ans_y = N;
            query(x,y,1);
            printf("%d\n",ans_x-ans_y);
        }
    }
    return 0;
}



相关文章推荐

poj3264 - Balanced Lineup

想看更多的解题报告: http://blog.csdn.net/wangjian8006/article/details/7870410                              ...

线段树的应用-poj3264的解法

将poj3264表述成一句话,就是:在一组数中,查询某个区间内的最大数与最小数的差。poj3264的原文地址为:http://acm.pku.edu.cn/JudgeOnline/problem?id...

POJ3264【线段树】

求区间最值…(基础,继续) code………..#include #include #include #include using namespace std;const int N=50007; s...

poj 2823 poj 3264 线段树维护最大最小值

题目:Sliding Window 大体内容: 题意:从后往前扫描k长的段,输出每段的最小值,最大值 解法:由于时间的原因可以选择线段树(RMQ更佳) 具体分析 ...

POJ3264 - Balanced Lineup - 线段树维护区间最大值、最小值

1.题目描述: Balanced Lineup Time Limit: 5000MS   Memory Limit: 65536K Total Submiss...

poj3264——Balanced Lineup(线段树+区间最大值与最小值)

DescriptionFor the daily milking, Farmer John’s N cows (1 ≤ N ≤ 50,000) always line up in the same o...

poj--3264Balanced Lineup+ST算法求区间最大最小值

题目链接:点击进入 其实这种动态查询区间最大最小值的题目,解法是有很多的,像是线段树和树状数组都是可以做的。ST算法效率和上面两种是一样的,但是编码更为简单。 ST算法是一种利用了递推思想进行计算...
  • acm_lkl
  • acm_lkl
  • 2015年08月08日 11:09
  • 557

CODE[VS] 3304 水果姐逛水果街I(线段树求区间最大最小值)

题目描述 Description 水果姐今天心情不错,来到了水果街。 水果街有n家水果店,呈直线结构,编号为1~n,每家店能买水果也能卖水果,并且同一家店卖与买的价格一样。 学过oi...

POJ 3264 Balanced Lineup 查询区间最大最小值 基础线状树水题

POJ 3264 Balanced Lineup 查询区间最大最小值 水题

POJ 3264 Balanced Lineup 求线段树区间最值

http://poj.org/problem?id=3264 Balanced Lineup Time Limit: 5000MS   Memory Limit: 65...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:poj3264(线段树求区间最大最小值)
举报原因:
原因补充:

(最多只允许输入30个字)