题目链接: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. solr 包地址

    http://archive.apache.org/dist/lucene/solr/6.3.0/

  2. P1664 每日打卡心情好

    题目背景 在洛谷中,打卡不只是一个简单的鼠标点击动作,通过每天在洛谷打卡,可以清晰地记录下自己在洛谷学习的足迹.通过每天打卡,来不断地暗示自己:我又在洛谷学习了一天,进而帮助自己培养恒心.耐心.细心. ...

  3. [转] Figuring out why my SVCHOST.EXE is at 100% CPU without complicated tools in Windows 7

    (转自:Figuring out why my SVCHOST.EXE is at 100% CPU without complicated tools in Windows 7 - Scott Ha ...

  4. SQL (一)定义变量以及变量赋值

    1.定义变量:declare @name varchar(20)  用declare定义一个名字为name的字符串类型的变量,变量前面需要加@ 2.为变量赋值:set @name = '%奥迪%' , ...

  5. Halcon学习笔记1

    转:https://www.cnblogs.com/hanzhaoxin/archive/2013/02/15/2912879.html 机器视觉工程应用主要可划分为硬件和软件两大部分. 硬件:工程应 ...

  6. 中间件及tomcat的内存溢出调优

    主要是这三个选项的调整需要根据主机的内存配置 以及业务量的使用情况调节 -Xmx4g -Xms4g -Xmn2g xmx 与xms一般设置为一样 xmn大致设置为xmx xms的三分之一   可以使用 ...

  7. UVA10129———欧拉道路

    题目 输入n(n≤100000)个单词,是否可以把所有这些单词排成一个序列,使得每个单词的第一个字母和上一个单词的最后一个字母相同(例如 acm,malform,mouse).每个单词最多包含1000 ...

  8. WPF知识点全攻略01- WPF相对WinFrom的优缺点

    对比WPF和WinFrom前,先来了解下GUI现阶段在用的其他一些开发技术: MFC:微软基础类库,以C++的形式封装了Windows API,加上一些实用工具类. QT:奇趣科技开发的跨平台C++图 ...

  9. Linux-RedHat7.2 安装nginx托管.net core2.0

    1.安装依赖包 yum -y install gcc gcc-c++ pcre pcre-devel openssl openssl-devel zlib zlib-devel 2.下载安装包 wge ...

  10. Java文件编译与反编译:javac命令和javap命令

    1.创建一个Test.java文件,并输入内容 public class Test{ private int m; public int inc(){ return m + 1; } } 2.使用ja ...