题目链接

给出一个有N个数的序列,编号0 - N - 1。进行Q次查询,查询编号i至j的所有数中,最大的数是多少。

例如: 1 7 6 3 1。i = 1, j = 3,对应的数为7 6 3,最大的数为7。(该问题也被称为RMQ问题)

输入

第1行:1个数N,表示序列的长度。(2 <= N <= 10000)
第2 - N + 1行:每行1个数,对应序列中的元素。(0 <= S[i] <= 10^9)
第N + 2行:1个数Q,表示查询的数量。(2 <= Q <= 10000)
第N + 3 - N + Q + 2行:每行2个数,对应查询的起始编号i和结束编号j。(0 <= i <= j <= N - 1)

输出 

共Q行,对应每一个查询区间的最大值。

输入样例

5
1
7
6
3
1
3
0 1
1 3
3 4

输出样例

7
7
3

Sparse Table解决Range Minimum/Maximum Query学习参考博客

代码参考博客

分析

ST用DP O(nlogn)预处理 ,O(1)查询。

设a[i]是要求区间最值的数列,RMQ[i, j]表示从第i个数起连续2^j个数中的最大值。

例如:

a数列为:3 2 4 5 6 8 1 2 9 7

RMQ[1,0]表示第1个数起,长度为2^0=1的最大值,其实就是3这个数。同理 RMQ[1,1] = max(3,2) = 3, RMQ[1,2]=max(3,2,4,5) = 5,RMQ[1,3] = max(3,2,4,5,6,8,1,2) = 8;

且[i,0]就等于a[i]。

状态转移方程RMQ[i, j]=max(RMQ[i,j-1], RMQ[i + 2^(j-1),j-1])。

 #include <iostream>
#include <cstdio>
#include <cmath>
#include <cstring>
#define maxn 10005
using namespace std; int a[maxn],RMQ[maxn][]; void RMQ_INIT(int n){
for(int i = ; i < n; ++i) RMQ[i][] = a[i];
for(int j = ; (<<j) <= n; ++j)
for(int i = ; i + (<<j) - < n; ++i)
RMQ[i][j] = max(RMQ[i][j-], RMQ[i + (<<(j-))][j-]);
} int Find(int L, int R){
int k = ;
while((<<(k+)) <= R-L+) k++;
return max(RMQ[L][k], RMQ[R-(<<k)+][k]);
} int main(){
int N,Q,L,R;
while(cin>>N){
memset(RMQ, , sizeof(RMQ));
for(int i=;i<N;++i) cin>>a[i];
RMQ_INIT(N);
cin>>Q;
while(Q--){
cin>>L>>R;
cout<<Find(L,R)<<endl;
}
}
return ;
}

最新文章

  1. c++局域网多播
  2. 《Continuous Delivery》 Notes 2: Configuration Management
  3. 带连接池的netty客户端核心功能实现剖解
  4. SP*
  5. 【液晶模块系列基础视频】4.1.X-GUI图形界面库-画线画圆等函数简介
  6. 在没有spineRunTime情况下手动使用spine数据
  7. laravel项目报错DecryptException:The MAC is invalid.
  8. ASP.NET 窗体间传值实现方法详解
  9. HAOI2007反素数
  10. POJ2752 - Seek the Name, Seek the Fame(KMP)
  11. javascript数组方法鉴赏一
  12. ES6(一)let const
  13. 【Hibernate】could not instantiate class.. from tuple] with root cause
  14. C# 封装SDK 获取摄像头的水平角度和垂直角度
  15. tcp和udp协议的聊天 和udp协议的时间同步机制-----编码
  16. shell 备份代码
  17. Kinect2.0点云数据获取
  18. 4、keepalived高可用nginx负载均衡
  19. mysql导入慢解决方法
  20. [转]Bing Maps Tile System 学习

热门文章

  1. [Xcode 实际操作]九、实用进阶-(10)定位设备的使用
  2. 【渗透测试】如何使用burpsuite对特殊密码进行爆破
  3. 跳跃表&amp;hash
  4. ADO winform注册
  5. linux 和windows 的定时任务
  6. JAVA常用知识总结(十四)——Servlet
  7. SVN状态图标消失的解决方法
  8. [android][avd位置修改][需自己手动]
  9. Apache——DBUtils框架ResultSetHandler接口使用
  10. Oracle查询排序asc/desc 多列 order by