POJ - 3264——Balanced Lineup(入门线段树)
| Time Limit: 5000MS | Memory Limit: 65536K | |
| Total Submissions: 68466 | Accepted: 31752 | |
| Case Time Limit: 2000MS | ||
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 题目链接: http://poj.org/problem?id=3264 题目大意: 给定一个区间N,并初始化该区间,Q次询问区间内的最大值减最小值。 题目分析: 这是一道基础入门级的线段树题目。线段树是二分的思想。开结构体存储节点的左、右区间和最大、最小值。根节点的左区间是1,右区间是N。 父节点分成左孩子和右孩子,即左孩子的区间为父节点的左区间到父节点的中值((l+r)/2),右孩子的区间为父节点的中值加一((l+r)/2+1)到父节点的右区间。 AC代码如下:
#include<stdio.h>
#include<algorithm>
using namespace std;
const int MAX=1E6+; struct s{
int left,right;
int maxx,minn;
}tree[MAX<<]; void btree(int k,int l,int r) //建树
{
tree[k].left=l; //节点左右区间更新
tree[k].right=r;
if(l==r) //叶子
{
scanf("%d",&tree[k].minn);
tree[k].maxx=tree[k].minn;
return ;
}
int mid=(l+r)/;
btree(k<<,l,mid); //左孩子
btree(k<<|,mid+,r); //右孩子
tree[k].maxx=max(tree[k<<].maxx,tree[k<<|].maxx); //更新节点最大值
tree[k].minn=min(tree[k<<].minn,tree[k<<|].minn); //更新节点最小值
} int ma,mi;
void query(int k,int l,int r) //询问
{
if(tree[k].left>=l&&tree[k].right<=r)
{
ma=max(tree[k].maxx,ma);
mi=min(tree[k].minn,mi);
return ;
}
int mid=(tree[k].left+tree[k].right)/;
if(mid>=r) //节点中值大于询问区间右边 询问左孩子
{
query(k<<,l,r);
}
else if(mid<l) //节点中值小于询问左边 询问右孩子
{
query(k<<|,l,r);
}
else //左、右都需要询问
{
query(k<<,l,r);
query(k<<|,l,r);
}
return ;
} int main()
{
int n,q;
scanf("%d%d",&n,&q);
btree(,,n);
for(int i=;i<=q;i++)
{
ma=-;mi=0x3f3f3f3f;
int a,b;
scanf("%d%d",&a,&b);
query(,a,b);
printf("%d\n",ma-mi);
}
return ;
}
POJ - 3264——Balanced Lineup(入门线段树)的更多相关文章
- 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 ...
- poj 3264 Balanced Lineup (线段树)
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 42489 Accepted: 20000 ...
- POJ 3264 Balanced Lineup 【线段树/区间最值差】
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 62103 Accepted: 29005 Cas ...
- POJ 3264 Balanced Lineup 【线段树】
<题目链接> 题目大意: 求给定区间内最大值与最小值之差. 解题分析: 线段树水题,每个节点维护两个值,分别代表该区间的最大和最小值即可. #include <cstdio> ...
- POJ 3264 Balanced Lineup【线段树】
题意:给出n个数,a1,a2,a3,---,an,再给出q次询问区间al到ar之间的最大值和最小值的差 学习线段树的第一道题目 学习的这一篇 http://www.cnblogs.com/kuangb ...
- POJ - 3264 Balanced Lineup(线段树或RMQ)
题意:求区间最大值-最小值. 分析: 1.线段树 #include<cstdio> #include<cstring> #include<cstdlib> #inc ...
- POJ 3264 Balanced Lineup (线段树查找最大最小值)
http://poj.org/problem?id=3264 题意:给你一个长度为n的序列a[N] (1 ≤ N ≤ 50000),询问Q(1 ≤ Q ≤ 200000) 次,每次输出[L, R]区间 ...
- 暑期训练狂刷系列——poj 3264 Balanced Lineup(线段树)
题目连接: http://poj.org/problem?id=3264 题目大意: 有n个数从1开始编号,问在指定区间内,最大数与最小数的差值是多少? 解题思路: 在节点中存储max,min,然后查 ...
- poj 3246 Balanced Lineup(线段树)
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 38942 Accepted: 18247 ...
随机推荐
- Django路由控制
本文目录 一 Django中路由的作用 二 简单的路由配置 三 有名分组 四 路由分发 五 反向解析 六 名称空间 七 django2.0版的path 回到目录 一 Django中路由的作用 URL配 ...
- mysql基操
创建数据表: create table tt1( id int, name varchar(20), age int,sex boolean ); insert into tt1 values(1,& ...
- 不小心跳进安装Django-redis的坑
为了写缓存这一块,我用pip install django-redis安装Django-redis. 它也把我的Django更新到最新了,我回头看下面的截图才发现的,把我的Django从1.8.2更新 ...
- HTML与CSS的一些知识(一)
一般写代码的时候,总会有些小错误.为了便于修改以及查找,所以代码格式要写规范,而且一定一定要写注释.因为有时候代码写得多了,真的连自己都找不到自己要找的东西在哪里.还有命名也要见名知意. 再说一些HT ...
- list,tuple,dict,set的增删改查
数据结构 list tuple dict set 增 append insert d['key']=value add 删 pop pop(0) d.pop('name') pop re ...
- Ubuntu 14.04 安装 sysrepo v0.7.5
参考: Tentative gNMI support with sysrepo protobuf-c/protobuf-c Ubuntu 14.04 安装 sysrepo v0.7.5 安装依赖: s ...
- C语言-第6次作业
1.本章学习总结 1.1思维导图 1.2 本章学习体会 学习感受:先是接触到网络工程导论的建立文件的方式,觉得很方便很好用,而后直接从代码的层面建立文件,觉得很新奇,更加方便,随着大作业的一步一步升级 ...
- vue数据变动监测
原文链接:https://blog.csdn.net/man_tutu/article/details/72148362 对象: 不能监测到: var vm = new Vue({ data:{ a: ...
- Unity3d外包—就找北京动点软件(长年承接Unity3d软件、游戏项目外包)
承接Unity3d体感企业项目.游戏项目外包 北京公司.专业团队,成员为专业Unity3d产品公司一线开发人员,有大型产品开发经验: 提供优质的售后服务,保证产品质量,轻量级产品可以提供规范清晰的源代 ...
- python __getattra__()
官网解释: object.__getattr__(self, name) Called when an attribute lookup has not found the attribute in ...