Balanced Lineup

Description

For the daily milking, Farmer John's N cows (1 ≤ N ≤ 50,000) always line up in the same order. One day Farmer John decides to organize a game of Ultimate Frisbee with some of the cows. To keep things simple, he will take a contiguous range of cows from the milking lineup to play the game. However, for all the cows to have fun they should not differ too much in height.

Farmer John has made a list of Q (1 ≤ Q ≤ 200,000) potential groups of cows and their heights (1 ≤ height ≤ 1,000,000). For each group, he wants your help to determine the difference in height between the shortest and the tallest cow in the group.

Input

Line 1: Two space-separated integers, N and Q
Lines 2..N+1: Line i+1 contains a single integer that is the height of cow i 
Lines N+2..N+Q+1: Two integers A and B (1 ≤ A ≤ B ≤ N), representing the range of cows from A to B inclusive.

Output

Lines 1..Q: Each line contains a single integer that is a response to a reply and indicates the difference in height between the tallest and shortest cow in the range.

Sample Input

6 3

1

7

3

4

2

5

1 5

4 6

2 2

Sample Output

6
3
0

报告:

题目大意: 有一排高度不一的牛(...),现在给出它们的高度,给几个区间求区间内的最高的牛和最矮的牛的“身高差”。

题解:

  自己写的时候是用结构体记录各个区间内的最大值和最小值,然后返回查询的区间所求的最大值和最小值的差。样例过了,但是其他的却WA了。。表示很奇怪,现在写博客才想起来我这一点还没想明白,就直接去看题解了........那先把这个只过得了样例的程序传了吧。

  .......

结果去调试发现连样例都没有过,于是分析了一下,这样写的话,如果查询区间在以分的区间两端,就只会直接返回一段的差值了。代码如下: 

 1 #include<iostream>
#include<cstdio>
#define l(u) (u<<1)
#define r(u) (u<<1|1)
using namespace std;
int n,q,highest,lowest;
int cow[];
struct pp{
int l,r,mins,maxs;
};
pp node[];
int min(int a,int b)
{
return a<b?a:b;
}
int max(int a,int b)
{
return a>b?a:b;
}
void build(int u,int left,int right)
{
node[u].l=left;node[u].r=right;
if (node[u].l==node[u].r)
{
node[u].mins=cow[left];
node[u].maxs=cow[left];
return ;
}
int mid=(left+right)>>;
build(l(u),left,mid);
build(r(u),mid+,right);
node[u].mins=min(node[l(u)].mins,node[r(u)].mins);
node[u].maxs=max(node[l(u)].maxs,node[r(u)].maxs);
}
int query(int u,int left,int right)
{
if (node[u].l==left&&node[u].r==right)
{
return node[u].maxs-node[u].mins;
}
int mid=(node[u].l+node[u].r)>>;
if (right<=mid) query(l(u),left,right);
else if (left>mid) query(r(u),left,right);
else
{
query(l(u),left,mid);
query(r(u),mid+,right);
}
}
int main()
{
freopen("balance.in","r",stdin);
cin>>n>>q;
for(int i=;i<=n;i++)
scanf("%d",&cow[i]);
build(,,n);
for(int i=;i<=q;i++)
{
int a,b;
//highest=0;//***
//lowest=1234567;//***
scanf("%d%d",&a,&b);
printf("%d\n",query(,a,b));
}
return ;
}

正确的代码中是用 high 和low 来记录比较最大值和最小值并且只是 void 并不 返回值,这样一来就可以得到正确的答案了。

代码如下:

 #include<iostream>
#include<cstdio>
#define l(u) (u<<1)
#define r(u) (u<<1|1)
using namespace std;
int n,q,highest,lowest;
int cow[];
struct pp{
int l,r,mins,maxs;
};
pp node[];
int min(int a,int b)
{
return a<b?a:b;
}
int max(int a,int b)
{
return a>b?a:b;
}
void build(int u,int left,int right)
{
node[u].l=left;node[u].r=right;
if (node[u].l==node[u].r)
{
node[u].mins=cow[left];
node[u].maxs=cow[left];
return ;
}
int mid=(left+right)>>;
build(l(u),left,mid);
build(r(u),mid+,right);
node[u].mins=min(node[l(u)].mins,node[r(u)].mins);
node[u].maxs=max(node[l(u)].maxs,node[r(u)].maxs);
}
void query(int u,int left,int right)
{
if (node[u].l==left&&node[u].r==right)
{
lowest=min(lowest,node[u].mins);//***
highest=max(highest,node[u].maxs);///***
return ;
}
int mid=(node[u].l+node[u].r)>>;
if (right<=mid) query(l(u),left,right);
else if (left>mid) query(r(u),left,right);
else
{
query(l(u),left,mid);
query(r(u),mid+,right);
}
}
int main()
{
//freopen("balance.in","r",stdin);
cin>>n>>q;
for(int i=;i<=n;i++)
scanf("%d",&cow[i]);
build(,,n);
for(int i=;i<=q;i++)
{
int a,b;
highest=;//***
lowest=;//***
scanf("%d%d",&a,&b);
query(,a,b);
printf("%d\n",highest-lowest);
}
return ;
}

注意事项:

1、定初值。

POJ 3264 Balanced Lineup 线段树 第三题的更多相关文章

  1. [POJ] 3264 Balanced Lineup [线段树]

    Balanced Lineup Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 34306   Accepted: 16137 ...

  2. poj 3264 Balanced Lineup(线段树、RMQ)

    题目链接: http://poj.org/problem?id=3264 思路分析: 典型的区间统计问题,要求求出某段区间中的极值,可以使用线段树求解. 在线段树结点中存储区间中的最小值与最大值:查询 ...

  3. POJ 3264 Balanced Lineup 线段树RMQ

    http://poj.org/problem?id=3264 题目大意: 给定N个数,还有Q个询问,求每个询问中给定的区间[a,b]中最大值和最小值之差. 思路: 依旧是线段树水题~ #include ...

  4. POJ 3264 Balanced Lineup (线段树)

    Balanced Lineup For the daily milking, Farmer John's N cows (1 ≤ N ≤ 50,000) always line up in the s ...

  5. POJ - 3264 Balanced Lineup 线段树解RMQ

    这个题目是一个典型的RMQ问题,给定一个整数序列,1~N,然后进行Q次询问,每次给定两个整数A,B,(1<=A<=B<=N),求给定的范围内,最大和最小值之差. 解法一:这个是最初的 ...

  6. 【POJ】3264 Balanced Lineup ——线段树 区间最值

    Balanced Lineup Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 34140   Accepted: 16044 ...

  7. Poj 3264 Balanced Lineup RMQ模板

    题目链接: Poj 3264 Balanced Lineup 题目描述: 给出一个n个数的序列,有q个查询,每次查询区间[l, r]内的最大值与最小值的绝对值. 解题思路: 很模板的RMQ模板题,在这 ...

  8. POJ 3264 Balanced Lineup【线段树区间查询求最大值和最小值】

    Balanced Lineup Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 53703   Accepted: 25237 ...

  9. poj 3264:Balanced Lineup(线段树,经典题)

    Balanced Lineup Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 32820   Accepted: 15447 ...

随机推荐

  1. Maven——使用Maven构建多模块项目

    原文:http://www.cnblogs.com/xdp-gacl/p/4242221.html 在平时的Javaweb项目开发中为了便于后期的维护,我们一般会进行分层开发,最常见的就是分为doma ...

  2. Spring MVC 之拦截器(八)

     在springMVC中实现拦截器有两种方式 1.实现HandlerInterceptor接口 2.继承HandlerInterceptorAdaptor类 编写拦截器: package com.cy ...

  3. Kafka文件的存储机制

    Kafka文件的存储机制 同一个topic下有多个不同的partition,每个partition为一个目录,partition命名的规则是topic的名称加上一个序号,序号从0开始. 每一个part ...

  4. VIm vi 使用 汇总

    x 删除当前光标下的字符dw 删除光标之后的单词剩余部分.d$ 删除光标之后的该行剩余部分.dd 删除当前行. c 功能和d相同,区别在于完成删除操作后进入INSERT MODEcc 也是删除当前行, ...

  5. http协议简述

    HTTP协议 客户端连上web 服务器后,若想获得 web 服务器中的某个 web 资源,需遵守一定的通讯格式, HTTP 协议用于定义客户端与 web 服务器通迅的格式. WEB浏览器与 WEB 服 ...

  6. linux下创建管理员组&nbsp;使用&nbsp;su&nbsp;-&nbsp;命令

    通常情况下,用户通过执行“su -”命令.输入正确的root密码,可以登录为root用户来对系统进行管理员级别的配置.但是,为了更进一步加强系统的安全性,有必要建立一个管理员的组,只允许这个组的用户来 ...

  7. VC++编译GSL

    目录 第1章 VC++    1 1.1 修改行结束符    1 1.2 修改#include "*.c" 为 #include "*.inl"    2 1. ...

  8. 增强Web可用性,你需要避免的七大设计错误

    Web设计给了你展示自我创新才能的平台,同时也要求你特别关注其中的诸多琐碎细节.优秀的Web设计师需要从设计前辈那里获得设计灵感,寻求他们给的建议,并反复推敲,以及付出诸多努力.职业博客作者Rajni ...

  9. Web前端开发面试题

    1. 以下的代码有问题吗?如果有你觉着应该如何修改? for(int i=0; i<list.size(); i++) {  .....  .....  if(...)  {   list.re ...

  10. Symmetric Tree [LeetCode]

    Problem description: http://oj.leetcode.com/problems/symmetric-tree/ Basic idea: Both recursive and ...