传送门: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. electron 项目的打包方式,以及 jquery 插件的修改使用

    < 一 > 应用打包 1,首先确定安装了 node 和 npm 2,全局安装打包依赖  => npm i electron-packager -g 3,打包命令 electron-p ...

  2. [Python]实践:实现探测Web服务质量

    来源:Python 自动化运维 技术与最佳实践 HTTP服务是最流行的互联网应用之一,服务质量的好坏关系到用户体验以及网站的运营服务水平,最常用的有两个标准:1.服务的可用性,比是否处于正常提供服务状 ...

  3. template.js 数据渲染引擎

    template.js 数据渲染引擎 template.js是一款JavaScript模板引擎,用来渲染页面的. 原理:提前将Html代码放进编写模板 <script id="tpl& ...

  4. flex 上下div固定, 中间div自适应

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  5. Spring boot 注册Filter , Listener, Servlet

    1: ServletRegistrationBean   Servlet @Bean public ServletRegistrationBean myServlet(){ ServletRegist ...

  6. Net操作Excel_NPOI

    Npoi 简介 1.整个Excel表格叫做工作表:WorkBook(工作薄),包含的叫页(工作表):Sheet:行:Row:单元格Cell. 2.Npoi 下载地址:http://npoi.codep ...

  7. vue.js 作一个用户表添加页面----初级

    使用vue.js 制作一个用户表添加页面,实际上是把原来需要使用js写的部分,改写成vue.js的格式 首先,想象一下,先做思考,我们要添加用户表,设涉及到哪些数据,一个是用户id,一个是用户名,一个 ...

  8. List根据时间字符串排序

    Collections.sort(resList, new Comparator<LoanApplyLogRes>() { @Override public int compare(Loa ...

  9. SQL SERVER 2000安装遇到的问题小汇总(转载)

    [1]安装程序配置服务器失败需要修改下注册表1 打开注册表 在"开始"--"运行"键入 "regedit"  2 删除注册表如下键值: HK ...

  10. 侧边栏收起展开效果,onmouseover,onmouseout

    //方法一<!doctype html> <html lang="en"> <head> <meta charset="UTF- ...