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

思路分析:

典型的区间统计问题,要求求出某段区间中的极值,可以使用线段树求解。

在线段树结点中存储区间中的最小值与最大值;查询时使用线段树的查询

方法并稍加修改即可进行查询区间中最大与最小值的功能。

代码(线段树解法):

#include <limits>
#include <cstdio>
#include <iostream>
using namespace std; const int MAX_N = ;
const int N_VAL = + ;
struct SegTreeNode
{
int valMin, valMax;
}; SegTreeNode segTree[MAX_N];
int val[N_VAL];
int valMax, valMin; int Max(int a, int b) { return a > b ? a : b; }
int Min(int a, int b) { return a > b ? b : a; }
void Build(int root, int nbegin, int nend, int arr[])
{
if (nbegin == nend)
{
segTree[root].valMax = arr[nbegin];
segTree[root].valMin = arr[nbegin];
}
else
{
int mid = (nbegin + nend) / ; Build( * root, nbegin, mid, arr);
Build( * root + , mid + , nend, arr);
segTree[root].valMax = Max(segTree[ * root].valMax, segTree[ * root + ].valMax);
segTree[root].valMin = Min(segTree[ * root].valMin, segTree[ * root + ].valMin);
}
} void Query(int root, int nbegin, int nend, int qbegin, int qend)
{
if (nbegin > qend || nend < qbegin)
return;
if (qbegin <= nbegin && qend >= nend)
{
if (valMax < segTree[root].valMax)
valMax = segTree[root].valMax;
if (valMin > segTree[root].valMin)
valMin = segTree[root].valMin;
return;
} int mid = (nbegin + nend) / ; Query( * root, nbegin, mid, qbegin, qend);
Query( * root + , mid + , nend, qbegin, qend);
} int main()
{
int qbegin, qend;
int count = , N, Q; scanf("%d%d", &N, &Q);
while (count++ < N)
scanf("%d", &val[count]); Build(, , N, val);
while (Q--)
{
valMax = INT_MIN, valMin = INT_MAX;
scanf("%d%d", &qbegin, &qend);
Query(, , N, qbegin, qend);
printf("%d\n", valMax - valMin);
} return ;
}

代码(RMQ解法):

#include <cstdio>
#include <cmath>
#include <iostream>
using namespace std; const int MAX_L = ;
const int MAX_N = + ;
int height[MAX_N];
int max_h[MAX_N][MAX_L], min_h[MAX_N][MAX_L]; void RmqMaxInit(int n)
{
for (int j = ; j < MAX_L; ++j)
{
for (int i = ; i < n; ++i)
{
if (j == )
max_h[i][j] = height[i];
else
{
max_h[i][j] = max_h[i][j - ];
int p = i + ( << (j - ));
if (p < n)
{
if (max_h[p][j - ] > max_h[i][j])
max_h[i][j] = max_h[p][j - ];
}
}
}
}
} int RmqMaxQuery(int l, int r)
{
if (l > r)
{
int temp = l;
l = r;
r = temp;
}
int k = log(r - l + ) / log();
return max_h[l][k] > max_h[r - ( << k) + ][k] ?
max_h[l][k] : max_h[r - ( << k) + ][k];
} void RmqMinInit(int n)
{
for (int j = ; j < MAX_L; ++j)
{
for (int i = ; i < n; ++i)
{
if (j == )
min_h[i][j] = height[i];
else
{
min_h[i][j] = min_h[i][j - ];
int p = i + ( << (j - ));
if (p < n)
{
if (min_h[p][j - ] < min_h[i][j])
min_h[i][j] = min_h[p][j - ];
}
}
}
}
} int RmqMinQuery(int l, int r)
{
if (l > r)
{
int temp = l;
l = r;
r = temp;
} int k = log(r - l + ) / log();
return min_h[l][k] < min_h[r - ( << k) + ][k] ?
min_h[l][k] : min_h[r - ( << k) + ][k];
} int main()
{
int num_len, query_num; scanf("%d %d", &num_len, &query_num);
for (int i = ; i < num_len; ++i)
scanf("%d", &height[i]);
RmqMaxInit(num_len);
RmqMinInit(num_len); for (int i = ; i < query_num; ++i)
{
int l = , r = ;
int min_height = , max_height = ; scanf("%d %d", &l, &r);
max_height = RmqMaxQuery(l - , r - );
min_height = RmqMinQuery(l - , r - );
printf("%d\n", max_height - min_height);
} return ;
}

poj 3264 Balanced Lineup(线段树、RMQ)的更多相关文章

  1. POJ 3264 Balanced Lineup 线段树RMQ

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

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

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

  3. POJ 3264 Balanced Lineup 线段树 第三题

    Balanced Lineup Description For the daily milking, Farmer John's N cows (1 ≤ N ≤ 50,000) always line ...

  4. POJ 3264 Balanced Lineup (线段树)

    Balanced Lineup For the daily milking, Farmer John's N cows (1 ≤ N ≤ 50,000) always line up in the s ...

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

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

  6. 【POJ】3264 Balanced Lineup ——线段树 区间最值

    Balanced Lineup Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 34140   Accepted: 16044 ...

  7. poj 3264 Balanced Lineup 区间极值RMQ

    题目链接:http://poj.org/problem?id=3264 For the daily milking, Farmer John's N cows (1 ≤ N ≤ 50,000) alw ...

  8. Poj 3264 Balanced Lineup RMQ模板

    题目链接: Poj 3264 Balanced Lineup 题目描述: 给出一个n个数的序列,有q个查询,每次查询区间[l, r]内的最大值与最小值的绝对值. 解题思路: 很模板的RMQ模板题,在这 ...

  9. POJ 3264 Balanced Lineup【线段树区间查询求最大值和最小值】

    Balanced Lineup Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 53703   Accepted: 25237 ...

随机推荐

  1. C#委托的简单剖析

    为什么在Button1的Click事件发生之后,button1_Click方法就会被调用呢? 实际上,在我们双击Button1的时候,IDE自动的添加了一段代码,该段代码位于“Form1.Design ...

  2. debug jdk

    1.解压jdk安装路径中的src.zip如:c:\src. 注意一般只选择编译java javax org 三个文件夹就足够了,剩余的文件夹删除掉 2.列出要编译的源文件:dir /B /S /X c ...

  3. google base之LockImpl

    为了兼容不同的平台,这个类采用了impl模式,win平台通过CRITICAL_SECTION, 这样的话还是相对比较简单,具体就不详解了,不过不得不说boost的实现方式就要复杂到哪里去了,当然,好处 ...

  4. CSDN博客排名第一名,何许人也

    CSDN博客排名第一名,何许人也 一.提出问题 CSDN博客排名第一名,何许人也. 分析截止时间是:2013年12月19日星期四22:00. 二.博客网址 http://blog.csdn.net/p ...

  5. JQuery初识

    一.什么是JQuery       JQuery官方网站上是这样解释的:JQuery是一个快速简洁的JavaScript库,它可以简化HTML文档的元素遍历.事件处理.动画及Ajax交互,快速开发We ...

  6. R与数据分析旧笔记(⑦)回归诊断

    回归诊断 回归诊断 1.样本是否符合正态分布假设? 2.是否存在离群值导致模型发生较大误差? 3.线性模型是否合理? 4.误差是否满足独立性.等方差.正态分布等假设条件? 5.是否存在多重共线性 正态 ...

  7. Cookie已经过时,细看Facebook, Google, Apple如何追踪用户

    http://www.infoq.com/cn/news/2014/10/cookie-facebook-google-apple 链接地址 Cookie,有时也用其复数形式Cookies,指某些网站 ...

  8. 一个简单的web框架实现

    一个简单的web框架实现 #!/usr/bin/env python # -- coding: utf-8 -- __author__ = 'EchoRep' from wsgiref.simple_ ...

  9. Oracle触发器(trigger):view,schema,database

    视图trigger, instead of 我们知道如果一个view只是由一个table构成,那在view上做啥操作没太多限制.如果view是由多个table组成那在view上做啥unpdate,in ...

  10. POJ 1679:The Unique MST(次小生成树&amp;&amp;Kruskal)

    The Unique MST Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 19941   Accepted: 6999 D ...