传送门:http://acm.tzc.edu.cn/acmhome/problemdetail.do?&method=showdetail&id=1698

时间限制(普通/Java):5000MS/50000MS     内存限制:65536KByte

描述

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.

输入

Line 1: Two space-separated integers, N and Q.
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 ≤ ABN), representing the range of cows from A to B inclusive.

输出

Lines 1..Q: Each line contains a single integer that is a response to a reply and indicates the difference in height between the tallest and shortest cow in the range.

样例输入

6 3
1
7
3
4
2
5
1 5
4 6
2 2

样例输出

6
3
0

思路:题目大意就是,给n个数m个查询,下面行输入n个数。m行输入m个查询,查询最大值和最小值的差。

rmq-st模板题。拿来练手的。作为丢人的初学线段树选手,也附上手打的线段树代码。

RMQ-ST代码:

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<string>
#include<cstdlib>
#include<cmath>
#include<stack>
#include<queue>
#include<set>
#include<map>
#include<vector>
#define LL long long
#include<assert.h>
using namespace std;
int a[],dm[][],dx[][];
void rmq(int num){
for(int i = ; i < num ; i++){
dm[i][] = dx[i][] = a[i];
}
for(int j = ; (<<j) <= num ; j++){
for(int i = ;i+(<<j)- < num ;i ++){
dx[i][j] = max(dx[i][j-],dx[i+(<<(j-))][j-]);
dm[i][j] = min(dm[i][j-],dm[i+(<<(j-))][j-]);
}
}
}
int qmax(int st,int ed){
int k = ;
while((<<(k+))<= ed - st + )k++;
return max(dx[st][k],dx[ed - (<<k) + ][k]);
}
int qmin(int st,int ed){
int k = ;
while((<<(k+))<= ed - st + )k++;
return min(dm[st][k],dm[ed - (<<k) + ][k]);
}
int main(){
int n,k;
while(~scanf("%d %d",&n,&k)){
memset(dx,,sizeof(dx));
memset(dm,,sizeof(dm));
for(int i = ; i < n ; i++)scanf("%d",&a[i]);
rmq(n);
while(k--){
int x,y;
scanf("%d %d",&x,&y);
printf("%d\n",qmax(x-,y-)-qmin(x-,y-));
}
}
}

线段树代码:

#include<cstdio>
#include<algorithm>
#include<iostream>
using namespace std;
const int maxn = ;
struct note{
int l,r;
int nMin,nMax;
}segTree[maxn<<];
int Max,Min;
int a[maxn];
void build(int i,int l,int r){
segTree[i].l = l;
segTree[i].r = r;
if(l==r){
segTree[i].nMin = segTree[i].nMax = a[l];
return;
}
int mid = (l+r)>>;
build(i<<,l,mid);
build(i<<|,mid+,r);
segTree[i].nMax = max(segTree[i<<].nMax,segTree[i<<|].nMax);
segTree[i].nMin = min(segTree[i<<].nMin,segTree[i<<|].nMin);
}
void query(int i,int l,int r){
if(segTree[i].nMax <= Max && segTree[i].nMin >= Min){
return;
}
if(segTree[i].l == l && segTree[i].r == r){
Max = max(segTree[i].nMax,Max);
Min = min(segTree[i].nMin,Min);
return;
}
int mid = (segTree[i].l + segTree[i].r) >> ;
if(r <= mid)
query(i<<,l,r);
else if(l > mid)
query(i<<|,l,r);
else{
query(i<<,l,mid);
query(i<<|,mid+,r);
}
}
int main(){
int n,m;
while(~scanf("%d %d",&n,&m)){
for(int i = ; i <= n ;i++)scanf("%d",&a[i]);
build(,,n);
while(m--){
int x,y;
Max = -;Min = ;
scanf("%d %d",&x,&y);
query(,x,y);
printf("%d\n",Max-Min);
}
}
}

TOJ1698/POJ3264Balanced Lineup (线段树 or RMQ-ST)的更多相关文章

  1. poj 3264 Balanced Lineup(线段树、RMQ)

    题目链接: http://poj.org/problem?id=3264 思路分析: 典型的区间统计问题,要求求出某段区间中的极值,可以使用线段树求解. 在线段树结点中存储区间中的最小值与最大值:查询 ...

  2. POJ - 3264 Balanced Lineup 线段树解RMQ

    这个题目是一个典型的RMQ问题,给定一个整数序列,1~N,然后进行Q次询问,每次给定两个整数A,B,(1<=A<=B<=N),求给定的范围内,最大和最小值之差. 解法一:这个是最初的 ...

  3. POJ3264Balanced Lineup 线段树练手

    题目意思:给定Q(1<=Q<=200000)个数A1,A2,```,AQ,多次求任一区间Ai-Aj中最大数和最小数的差 #include <iostream> #include ...

  4. POJ-3264 Balanced Lineup(区间最值,线段树,RMQ)

    http://poj.org/problem?id=3264 Time Limit: 5000MS     Memory Limit: 65536K Description For the daily ...

  5. POJ 3368 Frequent values 线段树与RMQ解法

    题意:给出n个数的非递减序列,进行q次查询.每次查询给出两个数a,b,求出第a个数到第b个数之间数字的最大频数. 如序列:-1 -1 1 1 1 1 2 2 3 第2个数到第5个数之间出现次数最多的是 ...

  6. 线段树+RMQ问题第二弹

    线段树+RMQ问题第二弹 上篇文章讲到了基于Sparse Table 解决 RMQ 问题,不知道大家还有没有印象,今天我们会从线段树的方法对 RMQ 问题再一次讨论. 正式介绍今天解决 RMQ 问题的 ...

  7. POJ - 3264 Balanced Lineup(线段树或RMQ)

    题意:求区间最大值-最小值. 分析: 1.线段树 #include<cstdio> #include<cstring> #include<cstdlib> #inc ...

  8. POJ 3264 Balanced Lineup 线段树RMQ

    http://poj.org/problem?id=3264 题目大意: 给定N个数,还有Q个询问,求每个询问中给定的区间[a,b]中最大值和最小值之差. 思路: 依旧是线段树水题~ #include ...

  9. [POJ] 3264 Balanced Lineup [线段树]

    Balanced Lineup Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 34306   Accepted: 16137 ...

随机推荐

  1. 白鹭引擎 - 文本类型 ( TextField, )

    1, 普通文本 class Main extends egret.DisplayObjectContainer { public constructor() { super(); this.addEv ...

  2. hive安装教程本地模式

    1.安装模式介绍: Hive官网上介绍了Hive的3种安装方式,分别对应不同的应用场景. a.内嵌模式(元数据保村在内嵌的derby种,允许一个会话链接,尝试多个会话链接时会报错) b.本地模式(本地 ...

  3. leetcode997

    class Solution: def findJudge(self, N: int, trust: 'List[List[int]]') -> int: if N==1 and len(tru ...

  4. [uwsgi: command not found]

    问题: pip install uwsgi 之后,运行uwsgi 报错:[uwsgi: command not found] 解决方案:建立软链接 ln -s /usr/local/python3/b ...

  5. delphi面向对象 继承窗体

    delphi继承form TFrmBase = class(TForm) procedure FormShow(Sender: TObject); end; procedure TFrmBase.Fo ...

  6. First changce exceptoin

      C++,改一点代码,F9,报一串地址错. First changce exceptoin是啥原因 退出也rad重进也不行,只能clean工程,完整编译才可以.感觉是没有把最新修改编译链接.   有 ...

  7. 机器学习入门-文本特征-word2vec词向量模型 1.word2vec(进行word2vec映射编码)2.model.wv['sky']输出这个词的向量映射 3.model.wv.index2vec(输出经过映射的词名称)

    函数说明: 1. from gensim.model import word2vec  构建模型 word2vec(corpus_token, size=feature_size, min_count ...

  8. 1.Zabbix配置[仅环境搭建]

    Zabbix配置分为两部分1.Zabbix服务端的配置 安装Zabbix源: [root@c71 ~]# rpm -ivh https://mirrors.aliyun.com/zabbix/zabb ...

  9. unzip解压带密码的压缩包

    // 解压 String pw = "123456"; String cmd = "unzip -P " + pw + " /root/lianlia ...

  10. Hydra密码破译工具

    Hydra简介 Hydra是著名黑客组织thc开发的一款开源的暴力密码破解工具,可以在线破解多种密码,目前已经被Backtrack和kali等渗透平台收录.除了命令行下的Hydra外,还提供了Hydr ...