poj 3264 Balanced Lineup(线段树、RMQ)
题目链接: 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)的更多相关文章
- POJ 3264 Balanced Lineup 线段树RMQ
http://poj.org/problem?id=3264 题目大意: 给定N个数,还有Q个询问,求每个询问中给定的区间[a,b]中最大值和最小值之差. 思路: 依旧是线段树水题~ #include ...
- [POJ] 3264 Balanced Lineup [线段树]
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 34306 Accepted: 16137 ...
- POJ 3264 Balanced Lineup 线段树 第三题
Balanced Lineup Description For the daily milking, Farmer John's N cows (1 ≤ N ≤ 50,000) always line ...
- 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 ...
- POJ - 3264 Balanced Lineup 线段树解RMQ
这个题目是一个典型的RMQ问题,给定一个整数序列,1~N,然后进行Q次询问,每次给定两个整数A,B,(1<=A<=B<=N),求给定的范围内,最大和最小值之差. 解法一:这个是最初的 ...
- 【POJ】3264 Balanced Lineup ——线段树 区间最值
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 34140 Accepted: 16044 ...
- 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 ...
- Poj 3264 Balanced Lineup RMQ模板
题目链接: Poj 3264 Balanced Lineup 题目描述: 给出一个n个数的序列,有q个查询,每次查询区间[l, r]内的最大值与最小值的绝对值. 解题思路: 很模板的RMQ模板题,在这 ...
- POJ 3264 Balanced Lineup【线段树区间查询求最大值和最小值】
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 53703 Accepted: 25237 ...
随机推荐
- 转场动画1-Push 动画
先上效果图: 这篇文章完全是为造轮子制作:原作者是码农界的吴彦祖 作者视频下载地址 好的,我梳理一下思路: 理清思路 ||转场动画可以理解为一个对象,在这个对象里封装了一个动画.具体的我们跟着代码走 ...
- WPF利用依赖属性和命令编写自定义控件
以实例讲解(大部分讲解在代码中) 1,新建一个WPF项目,添加一个用户控件之后在用户控件里面添加几个控件用作测试, <UserControl x:Class="SelfControlD ...
- Servlet基础知识(四)——Servlet过滤器Filter
一.什么是过滤器: 政府大楼的安检保安,它既能对进入政府大楼的人员进行检查,只允许检查符合要求的进入:同时他也负责对出大楼的人进行检查,看他带出的东西是否符合要求. 同样的,Servlet中的过滤器既 ...
- Java的函数与函数重载
关于Java的函数与函数重载 关于Java的函数与函数重载 1. 函数 假设有一个游戏程序,程序在运行过程中,要不断地发射炮弹.发射炮弹的动作都需要使用一段百行左右的程序代码,在每次发射炮弹的地方都要 ...
- .net mvc笔记4_依赖注入
一.Building Loosely Coupled Components MVC模式最重要的特点就是关注点分离.我们希望应用中的组件能尽可能的独立,相互之间即使有依赖也要在我们的控制之下. 在理想情 ...
- 4_Is Prime
4 // // ViewController.swift // Is Prime // // Created by ZC on 16/1/9. // Copyright © 2016年 ZC. All ...
- Qt 如何处理密集型耗时的事情(频繁调用QApplication::processEvents)
有时候需要处理一些跟界面无关的但非常耗时的事情,这些事情跟界面在同一个线程中,由于时间太长,导致界面无法响应,处于“假死”状态.例如:在应用程序中保存文件到硬盘上,从开始保存直到文件保存完毕,程序不响 ...
- 只有小于65535端口编程可以用,查看哪些端口被打开netstat -anp,nc命令,nmap命令
1024以下是系统保留的,从1024-65535是用户使用的 个人写的应用程序,尽量不要使用0到1024之间的端口号. 1024到65535我们编程可以用.这个不是Linux规定的,是socket规定 ...
- nodejs服务端开发学习笔记
正在学习中,不断改错... 学习了一段时间nodejs,对其中的很多东西还不是很理解,在网上看过很多的例子,希望通过自己的一些总结让自己了解的更全面些,同时也作为学习笔记留存备忘. 准备工作 node ...
- HDU1695-GCD(数论-欧拉函数-容斥)
GCD Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...