poj 3264 Balanced Lineup (RMQ算法 模板题)
RMQ支持操作:
Query(L, R): 计算Min{a[L],a[L+1], a[R]}。
预处理时间是O(nlogn), 查询只需 O(1)。
RMQ问题 用于求给定区间内的最大值/最小值问题。。询问的次数多的时候 好用。。
这个题目我至少得开数组开到 80000才能过,不知道为什么。。刚开始还写错了,贡献了好多RE和WA..
题目:http://poj.org/problem?id=3264
题意:给n个数,q次询问,求最值的差。。
#include <iostream>
#include <cstdio>
using namespace std;
const int maxn = ;
const int maxm = ;
int d_min[maxn][maxm],d_max[maxn][maxm],a[maxn];
int n; void RMQ_init()
{
int i,j;
for(i = ; i <= n; i++)
{
d_min[i][] = a[i];
d_max[i][] = a[i];
}
for(j = ; (<<j) <= n; j++)
for(i = ; i + j - <= n; i++)
{
d_min[i][j] = min(d_min[i][j-],d_min[i + (<<(j-))][j-]);
d_max[i][j] = max(d_max[i][j-],d_max[i + (<<(j-))][j-]);
}
} int RMQ_min(int l,int r)
{
int k = ;
while((<<(k+)) <= r-l+)
k++;
return min(d_min[l][k], d_min[r-(<<k)+][k]);
}
int RMQ_max(int l,int r)
{
int k = ;
while((<<(k+)) <= r-l+)
k++;
return max(d_max[l][k], d_max[r-(<<k)+][k]);
}
int main()
{
int q,l,r,i;
scanf("%d%d",&n,&q);
for(i = ; i <= n; i++)
scanf("%d",&a[i]);
RMQ_init(); while(q--)
{
scanf("%d%d",&l,&r);
printf("%d\n",RMQ_max(l,r)-RMQ_min(l,r));
}
return ;
}
我的模板:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <algorithm>
using namespace std;
const int maxn = ;
const int maxm = ;
int d_min[maxn][maxm],d_max[maxn][maxm],a[maxn];
int n; void RMQ_init()
{
int i,j;
for(i = ; i <= n; i++) //数组下标从1开始的。
{
d_min[i][] = a[i];
d_max[i][] = a[i];
}
for(j = ; (<<j) <= n; j++)
for(i = ; i + j - <= n; i++)
{
d_min[i][j] = min(d_min[i][j-],d_min[i + (<<(j-))][j-]);
d_max[i][j] = max(d_max[i][j-],d_max[i + (<<(j-))][j-]);
}
} int RMQ_min(int l,int r)
{
int k = ;
while((<<(k+)) <= r-l+)
k++;
return min(d_min[l][k], d_min[r-(<<k)+][k]);
}
int RMQ_max(int l,int r)
{
int k = ;
while((<<(k+)) <= r-l+)
k++;
return max(d_max[l][k], d_max[r-(<<k)+][k]);
}
int main()
{
int i,l,r;
cin>>n;
for(i = ; i <= n; i++) //数组下标从1开始的。
cin>>a[i];
RMQ_init();
while(cin>>l>>r)
{
cout<<RMQ_min(l,r)<<endl;
cout<<RMQ_max(l,r)<<endl;
}
return ;
}
poj 3264 Balanced Lineup (RMQ算法 模板题)的更多相关文章
- Poj 3264 Balanced Lineup RMQ模板
题目链接: Poj 3264 Balanced Lineup 题目描述: 给出一个n个数的序列,有q个查询,每次查询区间[l, r]内的最大值与最小值的绝对值. 解题思路: 很模板的RMQ模板题,在这 ...
- poj 3264 Balanced Lineup (RMQ)
/******************************************************* 题目: Balanced Lineup(poj 3264) 链接: http://po ...
- [POJ] 3264 Balanced Lineup [ST算法]
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 34306 Accepted: 16137 ...
- POJ - 3264 Balanced Lineup (RMQ问题求区间最值)
RMQ (Range Minimum/Maximum Query)问题是指:对于长度为n的数列A,回答若干询问RMQ(A,i,j)(i,j<=n),返回数列A中下标在i,j里的最小(大)值,也就 ...
- POJ 3264 Balanced Lineup RMQ ST算法
题意:有n头牛,编号从1到n,每头牛的身高已知.现有q次询问,每次询问给出a,b两个数.要求给出编号在a与b之间牛身高的最大值与最小值之差. 思路:标准的RMQ问题. RMQ问题是求给定区间内的最值问 ...
- POJ 3264 Balanced Lineup(ST模板)
链接:http://poj.org/problem?id=3264 题意:给n个数,求一段区间L,R的最大值 - 最小值,Q次询问 思路:ST表模板,预处理区间最值,O(1)复杂度询问 AC代码: # ...
- POJ 3264 Balanced Lineup -- RMQ或线段树
一段区间的最值问题,用线段树或RMQ皆可.两种代码都贴上:又是空间换时间.. RMQ 解法:(8168KB 1625ms) #include <iostream> #include < ...
- POJ 3264 Balanced Lineup(RMQ)
点我看题目 题意 :N头奶牛,Q次询问,然后给你每一头奶牛的身高,每一次询问都给你两个数,x y,代表着从x位置上的奶牛到y位置上的奶牛身高最高的和最矮的相差多少. 思路 : 刚好符合RMQ的那个求区 ...
- POJ 3264 Balanced Lineup 【ST表 静态RMQ】
传送门:http://poj.org/problem?id=3264 Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total S ...
随机推荐
- Scrum10-22
Time:2013-10-22 Author:居玉皓 Things we have done since yesterday's meeting: 在今天的Scrum中,STORY1 开发前期准备工作 ...
- Careercup - Facebook面试题 - 5998719358992384
2014-05-02 00:22 题目链接 原题: Given a matrix consisting of 's. 题目:给定一个01矩阵,找出由1构成的连通分量中最大的一个. 解法:四邻接还是八邻 ...
- Android journey 1@关于编码风格和命名规范
/* * 1.关于编程风格:每一位程序猿可能都有自己独特的编程风格,但是有些规则是大家都必须遵守的,特别 * 是在工作的过程中,良好的代码风格能大大提高代码本身的可阅读性和维护性,也更有利于别人修改你 ...
- 编译dubbo2.5.4时遇到的问题及解决
dubbo的官方git地址为:https://github.com/alibaba/dubbo 按照其流程进行下载及编译,遇到的问题为: 1. 执行 mvn clean install -Dmaven ...
- POJ 3723 Conscription 最小生成树
题目链接: 题目 Conscription Time Limit: 1000MS Memory Limit: 65536K 问题描述 Windy has a country, and he wants ...
- Jquery.linq 使用示例
http://linqjs.codeplex.com/ /*Linq JS*/ //range var aa = Enumerable.range(1, 10).toArray(); var kk = ...
- linux 下 apache启动、停止、重启命令
基本的操作方法: 本文假设你的apahce安装目录为/usr/local/apache2,这些方法适合任何情况 apahce启动命令: 推荐/usr/local/apache2/bin/apachec ...
- javax.mail.MessagingException: 501 Syntax: HELO hostname Linux端异常解决
在项目里面使用javamail在window环境正常,放在服务器上面的时候抛出异常javax.mail.MessagingException: 501 Syntax: HELO hostname ,原 ...
- Cent Os 常用操作
开放端口 编辑iptables文件(/etc/sysconfig/iptables) -A INPUT -m state --state NEW -m tcp -p tcp --dport xx端口号 ...
- Python-aiohttp百万并发
http://www.aikaiyuan.com/10935.html 本文将测试python aiohttp的极限,同时测试其性能表现,以分钟发起请求数作为指标.大家都知道,当应用到网络操作时,异步 ...