题目链接:http://poj.org/problem?id=3264

题目大意:
在给定一堆牛的数量以及其高度的时候,每次给定一段区间,求这个区间内最高的牛和最矮的牛的高度之差为多少。

可以直接利用RMQ求出区间最大最小相减即可,一道模板题- -。

 #include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <iostream>
using namespace std;
#define N 50010 int maxn[N][] , minn[N][] , n , q , val[N]; void RMQ()
{
memset(maxn , , sizeof(maxn));
memset(minn , 0x3f , sizeof(minn));
for(int i= ; i<=n ; i++) maxn[i][] = minn[i][] = val[i];
for(int i= , j= ; j<=n ; i++ , j<<=){
for(int k= ; k+j-<=n ; k++){
int la = k+(j>>);
maxn[k][i] = max(maxn[k][i-] , maxn[la][i-]);
minn[k][i] = min(minn[k][i-] , minn[la][i-]);
}
}
} int query(int s , int t)
{
int del = t-s+;
int j = (int)(log10(del)/log10())+;
int la = t-(<<(j-))+;
return max(maxn[s][j-] , maxn[la][j-])-min(minn[s][j-] , minn[la][j-]);
} int main()
{
// freopen("in.txt" , "r" , stdin);
while(~scanf("%d%d" , &n , &q))
{
for(int i= ; i<=n ; i++) scanf("%d" , &val[i]);
RMQ();
while(q--){
int s , t;
scanf("%d%d" , &s , &t);
printf("%d\n" , query(s , t));
}
}
return ;
}

RMQ

这道题目用线段树能快速的求解,因为此处不涉及更新,所以无需写update函数

不同于之前只定义一个tree数组,这回我们需要定义一个Max和一个Min数组分别子弟想存放较大和较小值

通过query找到区间内的最大值q,和最小值p,那么q-p便是我们所求的

 #include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std; #define N 50005
#define INF 0x3f3f3f3f int height[N],Min[*N],Max[*N],D; int query(int a,int b)
{
int i=D+a-,j=b+D+;
int p=INF,q=;
//if(a==b){return 0;}
for(;i^j^;i>>=,j>>=){
if(~i&){
p=min(p,Min[i^]);
q=max(q,Max[i^]);
}
if(j&){
p=min(p,Min[j^]);
q=max(q,Max[j^]);
}
}
return q-p;
}
int main()
{
int n,Q,a,b;
while(scanf("%d%d",&n,&Q)!=EOF){
memset(Min,,sizeof(Min));
memset(Max,0x3f,sizeof(Max));
for(D=;D<n+;D<<=);
for(int i=;i<=n;i++){
scanf("%d",&height[i]);
Min[D+i]=Max[D+i]=height[i];
}
for(int i=D-;i>=;i--){
Min[i]=min(Min[i<<],Min[i<<|]);
Max[i]=max(Max[i<<],Max[i<<|]);
}
for(int i=;i<=Q;i++){
scanf("%d%d",&a,&b);
printf("%d\n",query(a,b));
}
}
return ;
}

HDU 3264 区间内的最大最小之差的更多相关文章

  1. POJ-3264-Balanced Lineup-线段树模板题-查询区间内最大值和最小值之差

    For the daily milking, Farmer John's N cows (1 ≤ N ≤ 50,000) always line up in the same order. One d ...

  2. hdu 3473 区间条件极值 - 区间 差的绝对值 之和的最小

    题目传送门//res tp hdu 目的 对长度为n的区间,给定q个子区间,求一x,使得区间内所有元素与x的差的绝对值之和最小. 多测. n 1e5 q 1e5 ai [1,1e9] (i∈[1,n] ...

  3. HDU 4417 Super Mario(主席树求区间内的区间查询+离散化)

    Super Mario Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Tota ...

  4. hdu 4630 查询[L,R]区间内任意两个数的最大公约数

    No Pain No Game Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  5. hdu 4638 树状数组 区间内连续区间的个数(尽可能长)

    Group Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  6. HDU 3709 Balanced Number 求区间内的满足是否平衡的数量 (数位dp)

    平衡数的定义是指,以某位作为支点,此位的左面(数字 * 距离)之和 与右边相等,距离是指某位到支点的距离; 题意:求区间内满足平衡数的数量 : 分析:很好这又是常见的数位dp , 不过不同的是我们这次 ...

  7. hdu 5023(线段树区间染色,统计区间内颜色个数)

    题目描述:区间染色问题,统计给定区间内有多少种颜色? 线段树模板的核心是对标记的处理 可以记下沿途经过的标记,到达目的节点之后一块算,也可以更新的时候直接更新到每一个节点 Lazy操作减少修改的次数( ...

  8. hdu 4283 区间dp

    You Are the One Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

  9. hdu3437 划分树 区间内小于第K大的值得和

    Minimum Sum Time Limit: 16000/8000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Tot ...

随机推荐

  1. 记一次有关spark动态资源分配和消息总线的爬坑经历

    问题: 线上的spark thriftserver运行一段时间以后,ui的executor页面上显示大量的active task,但是从job页面看,并没有任务在跑.此外,由于在yarn mode下, ...

  2. Smart 组件 vs Dumb 组件

    大家已经知道,只会接受 props 并且渲染确定结果的组件我们把它叫做 Dumb 组件,这种组件只关心一件事情 —— 根据 props 进行渲染. Dumb 组件最好不要依赖除了 React.js 和 ...

  3. maven-ali镜像网站setting.xml

    简述 使用maven管理jar包的时候,有可能会有网络限制,要解决的这个问题的话可以使用ali的镜像网站. 创建文件 创建settings.xml,内容如下 <settings xmlns=&q ...

  4. SQL系列函数——字符串函数

    1.charindex函数用来寻找一个指定的字符(串)在另一个字符串中的起始位置,返回一个整数,没找到就返回0. select CHARINDEX('SQL','Microsoft SQL SERVE ...

  5. 利用伪类写一个自定义checkbox和radio

    首先是效果图来一张 再来一张html结构 关键的CSS来了~ 首先呢要把input标签设置为display: none;  因为自定义的原理是通过label的for属性,来点击label转向为点击in ...

  6. android AutoCompleteTextView 实现手机号格式化,附带清空历史的操作

    有个小伙伴遇到了这样一个问题,就是AutoCompleteTextView实现自动填充的功能.同时要具备手机格式化的功能.下拉列表最后一行是有个清除历史的功能.可是点击“清除历史”却把文字要设置进去A ...

  7. 版本号比较versioncompare方法,java实现

    测试

  8. css3 calc()属性介绍以及自适应布局使用方法

    前端知识 Calc()介绍 calc的英文是calculate的缩写,中文为计算的意思,是css3的一个新增的功能,用来只当元素的长度.比如说:你可以用calc()给元素margin.padding. ...

  9. Python3简明教程(十)—— 异常

    在本节我们学习 Python 的异常以及如何在你的代码中处理它们. 异常 在程序执行过程中发生的任何错误都是异常.每个异常显示一些相关的错误信息,比如你在 Python3 中使用 Python2 独有 ...

  10. dig - 发送域名查询信息包到域名服务器

    SYNOPSIS(总览) dig [@ server ] domain [Aq query-type ] [Aq query-class ] [+ Aq query-option ] [-Aq dig ...