HDU 3264 区间内的最大最小之差
题目链接: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 区间内的最大最小之差的更多相关文章
- 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 ...
- hdu 3473 区间条件极值 - 区间 差的绝对值 之和的最小
题目传送门//res tp hdu 目的 对长度为n的区间,给定q个子区间,求一x,使得区间内所有元素与x的差的绝对值之和最小. 多测. n 1e5 q 1e5 ai [1,1e9] (i∈[1,n] ...
- HDU 4417 Super Mario(主席树求区间内的区间查询+离散化)
Super Mario Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
- hdu 4630 查询[L,R]区间内任意两个数的最大公约数
No Pain No Game Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- hdu 4638 树状数组 区间内连续区间的个数(尽可能长)
Group Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Subm ...
- HDU 3709 Balanced Number 求区间内的满足是否平衡的数量 (数位dp)
平衡数的定义是指,以某位作为支点,此位的左面(数字 * 距离)之和 与右边相等,距离是指某位到支点的距离; 题意:求区间内满足平衡数的数量 : 分析:很好这又是常见的数位dp , 不过不同的是我们这次 ...
- hdu 5023(线段树区间染色,统计区间内颜色个数)
题目描述:区间染色问题,统计给定区间内有多少种颜色? 线段树模板的核心是对标记的处理 可以记下沿途经过的标记,到达目的节点之后一块算,也可以更新的时候直接更新到每一个节点 Lazy操作减少修改的次数( ...
- hdu 4283 区间dp
You Are the One Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...
- hdu3437 划分树 区间内小于第K大的值得和
Minimum Sum Time Limit: 16000/8000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Tot ...
随机推荐
- 你不知道的border-radius
对于border-radius这个属性,我们知道它可以用来设置边框圆角,利用它我们可以画出很多形状 这就需要了解到border-radius的各式写法: border-radius的写法: 1.只设置 ...
- RAID基础
磁盘类型 类型 IDE Integrated Drive Electronics SATA Srial ATA SCSI Small Computer System Interface FC Fibe ...
- ES相关概念理解
Elasticsearch特点:分布式,高性能,高可用,高伸缩的搜索和分析: 1)可作为一个大型分布式集群,处理PB级别的数据,服务大型公司,亦可运行在少数或单台设备上服务小型公司 分布式的特性: E ...
- RHEL 7.2 源码安装Python 3.6.2报错
报错代码:zipimport.ZipImportError: can't decompress data; zlib not available 一条命令解决:yum install zlib-dev ...
- 更新项目,uwsgi重新加载和日志文件
uwsgi --reload /var/run/uwsgi.pid uwsgi.pid是uwsgi进程文件 /var/log/uwsgi.log
- LSP
Liskov Substitution Principle里氏替换原则,OCP作为OO的高层原则,主张使用“抽象(Abstraction)”和“多态(Polymorphism)”将设计中的静态结构改为 ...
- AJPFX:不用递归巧妙求出1000的阶乘所有零和尾部零的个数
package com.jonkey.test; import java.math.BigInteger; public class Test6 { /*** @param args* 需求:求出1 ...
- iOS 动画(基于Lottie封装)
一般app中都会带有动画,而如果是一些复杂的动画,不但实现成本比较高,而且实现效果可能还不能达到UI想要的效果,于是我们可以借助lottie来完成我们想要的动画. lottie动画1.gif ...
- iOS开发中的HTML解析
在进行解析前,先将下面的第三方类添加到工程中: 添加以上三个类必须添加一个库,这个库是:libxml2.2.dylib. 还需要设置一些路径参数这个路径的设置,在 targets中,在build se ...
- js中json处理总结之JSON.parse
踩过的坑都将成为路上的风景.队友在cookie中已存以下值: address_info {"address_name":"人民大会堂","...lng ...