POJ 3264 Balanced Lineup 线段树 第三题
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
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
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 线段树 第三题的更多相关文章
- [POJ] 3264 Balanced Lineup [线段树]
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 34306 Accepted: 16137 ...
- poj 3264 Balanced Lineup(线段树、RMQ)
题目链接: http://poj.org/problem?id=3264 思路分析: 典型的区间统计问题,要求求出某段区间中的极值,可以使用线段树求解. 在线段树结点中存储区间中的最小值与最大值:查询 ...
- POJ 3264 Balanced Lineup 线段树RMQ
http://poj.org/problem?id=3264 题目大意: 给定N个数,还有Q个询问,求每个询问中给定的区间[a,b]中最大值和最小值之差. 思路: 依旧是线段树水题~ #include ...
- 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 ...
- POJ - 3264 Balanced Lineup 线段树解RMQ
这个题目是一个典型的RMQ问题,给定一个整数序列,1~N,然后进行Q次询问,每次给定两个整数A,B,(1<=A<=B<=N),求给定的范围内,最大和最小值之差. 解法一:这个是最初的 ...
- 【POJ】3264 Balanced Lineup ——线段树 区间最值
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 34140 Accepted: 16044 ...
- Poj 3264 Balanced Lineup RMQ模板
题目链接: Poj 3264 Balanced Lineup 题目描述: 给出一个n个数的序列,有q个查询,每次查询区间[l, r]内的最大值与最小值的绝对值. 解题思路: 很模板的RMQ模板题,在这 ...
- POJ 3264 Balanced Lineup【线段树区间查询求最大值和最小值】
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 53703 Accepted: 25237 ...
- poj 3264:Balanced Lineup(线段树,经典题)
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 32820 Accepted: 15447 ...
随机推荐
- iOS开发之总结
NO.1 要孜孜不倦的学习有句话叫技多不压身,编程本来就是一个更新换代非常快的工作.每年都有新的技术出现,我认为要成为一个出色的程序员只掌握一门语言肯定是不行的.那么,要怎么选择自己的第二门,甚至第三 ...
- mysql+tomcat+spring 配置心得(从0开始搭环境)
前几天公司竞一个标要做个POC,前端AugularJs做mobile界面,后端Spring MVC做Restful API供前端调用. 时间紧急,大家都忙,so我这个不写代码的闲人花一上午配了一套Sp ...
- C/C++中堆与栈
本文介绍C/C++中堆,栈及静态数据区. 五大内存分区 在C++中,内存分成5个区,他们分别是堆.栈.自由存储区.全局/静态存储区和常量存储区.下面分别来介绍: 栈,就是那些由编译器在需要的时候分 ...
- Hibernate的Restrictions用法
Restrictions.eq --> equal,等于. Restrictions.allEq --> 参数为Map对象,使用key/value进行多个等于的比对,相当于多个Restri ...
- laravel实现第三方登录
https://github.com/laravel/socialite 这是官方的第三方登录包,支持很多国外的第三方登录 https://github.com/overtrue/socialite ...
- Java集合框架:HashMap
转载: Java集合框架:HashMap Java集合框架概述 Java集合框架无论是在工作.学习.面试中都会经常涉及到,相信各位也并不陌生,其强大也不用多说,博主最近翻阅java集合框架的源码以 ...
- js 中 continue 与 break 熟练使用
//break:在循环体中,遇到break,整个循环都结束了,后面的累加操作也不在执行了,并且循环体中,只要遇到break,那么循环体break后面的代码都不在执行了 //continue:在循环体中 ...
- 如何使用Retrofit获取服务器返回来的JSON字符串
有关Retrofit的简单集成攻略,大家可以参考我此前的一篇文章有关更多API文档的查阅请大家到Retrofit官网查看. 在大家使用网络请求的时候,往往会出现一种情况:需要在拿到服务器返回来的JSO ...
- (19)odoo中的javascript
-----------更新日期15:17 2016-02-16 星期二-----------* 用到的js库 我们可以打开 addons/web/views/webclient_template. ...
- C/C++源代码到可执行程序的过程详解
编译,编译程序读取源程序(字符流),对之进行词法和语法的分析,将高级语言指令转换为功能等效的汇编代码,再由汇编程序转换为机器语言,并且按照操作系统对可执行文件格式的要求链接生成可执行程序. 源代码-- ...