BZOJ 1699: [Usaco2007 Jan]Balanced Lineup排队( RMQ )
2015-06-02 21:39
531 查看
RMQ..
-------------------------------------------------------------------------------
#include<cstdio>#include<cstring>#include<algorithm>#include<iostream> #define rep( i , n ) for( int i = 0 ; i < n ; ++i )#define clr( x , c ) memset( x , c , sizeof( x ) ) using namespace std; const int INF = int( 1e8 );const int maxn = 50000 + 5;const int maxlog = 18; int Max[ maxn ][ maxlog ] , Min[ maxn ][ maxlog ];int n; inline int read() { char c = getchar(); while( ! isdigit( c ) ) c = getchar(); int ans = 0; while( isdigit( c ) ) { ans = ans * 10 + c - '0'; c = getchar(); } return ans;} void RMQ_init() { for( int i = 1 ; ( 1 << i ) <= n ; ++i ) for( int j = 0; j + ( 1 << i ) <= n ; j++ ) Max[ j ][ i ] = max( Max[ j ][ i - 1 ] , Max[ j + ( 1 << ( i - 1 ) ) ][ i - 1 ] ) , Min[ j ][ i ] = min( Min[ j ][ i - 1 ] , Min[ j + ( 1 << ( i - 1 ) ) ][ i - 1 ] ); } int Query( int l , int r ) { int MIN = INF , MAX = -INF; int log = 0; while( ( 1 << ( log + 1 ) ) <= r - l + 1 ) log++; MAX = max( Max[ l ][ log ] , Max[ r - ( 1 << log ) + 1 ][ log ] ); MIN = min( Min[ l ][ log ] , Min[ r - ( 1 << log ) + 1 ][ log ] ); return MAX - MIN; } int main() { freopen( "test.in" , "r" , stdin ); int q; cin >> n >> q; rep( i , n ) Max[ i ][ 0 ] = Min[ i ][ 0 ] = read(); RMQ_init(); while( q-- ) { int l = read() - 1, r = read() - 1; printf( "%d\n" , Query( l , r ) ); } return 0;}
-------------------------------------------------------------------------------
1699: [Usaco2007 Jan]Balanced Lineup排队
Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1038 Solved: 641
[Submit][Status][Discuss]
Description
每天,农夫 John 的N(1 <= N <= 50,000)头牛总是按同一序列排队. 有一天, John 决定让一些牛们玩一场飞盘比赛. 他准备找一群在对列中为置连续的牛来进行比赛. 但是为了避免水平悬殊,牛的身高不应该相差太大. John 准备了Q (1 <= Q <= 180,000) 个可能的牛的选择和所有牛的身高 (1 <= 身高 <= 1,000,000). 他想知道每一组里面最高和最低的牛的身高差别. 注意: 在最大数据上, 输入和输出将占用大部分运行时间.Input
* 第一行: N 和 Q. * 第2..N+1行: 第i+1行是第i头牛的身高.* 第N+2..N+Q+1行: 两个整数, A 和 B (1 <= A <= B <= N), 表示从A到B的所有牛.
Output
*第1..Q行: 所有询问的回答 (最高和最低的牛的身高差), 每行一个.Sample Input
6 31
7
3
4
2
5
1 5
4 6
2 2
Sample Output
63
0
HINT
Source
Gold相关文章推荐
- 【Android】asynchronous http client
- webservice soapheader验证方法
- winceAPI
- OC基础学习——SEL(选择器类型)和Class的学习
- Python 代码风格学习一
- 基本命令行
- git fetch 和git merge 和git pull的区别
- redis字符串类型
- 怎样把经纬度坐标转换为空间直角坐标
- 虚拟机安装
- klg5
- 为大数据处理点亮一盏明灯----Spark知识系统化整理分享
- NIO与传统IO的区别
- XAAR128/200dpi
- klg4
- 题目1503:二叉搜索树与双向链表
- poj2594 (最小路径覆盖 + floyd)
- webservice跨域文件,好多年前的东西,远程调用,js服务器端使用,可以远程调用
- JavaScript读书笔记(1)
- 百度之夜分享移动搜索优化策略