AC G++ 826ms 146MB

思路:

  时间复杂度O(nlogn)。

 //#include <bits/stdc++.h>
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <set>
#include <deque>
#include <map>
#include <algorithm>
#include <vector>
#include <iostream>
#define max(X,Y) ((X) > (Y) ? (X) : (Y))
#define min(X,Y) ((X) < (Y) ? (X) : (Y))
#define pii pair<int,int>
#define back que[rear-1]
#define INF 0x3f3f3f3f
#define LL long long
#define ULL unsigned long long
using namespace std;
const double PI = acos(-1.0);
const int N=1e6+;
int a[N];
struct ST
{
int st[N][];
void init(int a[],int n) //注意a的下标
{
for(int i=; i<=n; i++) st[i][]=a[i];
for(int q=; (<<q)<=n; q++) //以(1<<i)为距离
for(int j=; j+(<<q)-<=n; j++) //枚举起点
st[j][q]=min(st[j][q-], st[j+(<<q-)][q-]);
}
int query(int L,int R)
{
int len=R-L+;
for(int i=; i>=; i--)//这里可以预处理
{
if( (len>>i)& )
{
return min(st[L][i], st[R-(<<i)+][i]);
}
} }
}st; int main()
{
//freopen("input.txt", "r", stdin);
int n, m, L, R;scanf("%d",&n);
for(int i=; i<=n; i++) scanf("%d",&a[i]);
st.init(a,n); scanf("%d",&m);
while(m--)
{
scanf("%d%d",&L,&R);
printf("%d\n", st.query(L,R));
}
return ;
}

AC代码

  用模板重打了一次。

 #include <bits/stdc++.h>
using namespace std;
const int N=;
int w[N], pre[N][], n, q;
void pre_cal()
{
for(int i=; i<n; i++) pre[i][]=w[i];
for(int i=,q=; i<=n; i*=,q++)
for(int j=; j<n; j++)
if(j+i-<n) pre[j][q]=min(pre[j][q-],pre[j+i/][q-]);
else break;
}
int main()
{
//freopen("input.txt", "r", stdin);
cin>>n;
for(int i=; i<n; i++) scanf("%d",&w[i]); //输入重量
pre_cal(); //预处理 cin>>q;
int L, R;
for(int i=; i<q; i++) //输入查询,并直接处理输出
{
scanf("%d%d", &L, &R);
int len=R-L+, tmp=, cnt=; for(int i=; i<; i++)//找出二进制最高位的1
{
if(!(len>>i))
{
tmp=((len>>(i-))<<(i-));
break;
}
cnt++;
}
if(R==L) printf("%d\n",w[L-]);
else if(tmp==len) printf("%d\n",pre[L-][cnt-]);//这步其实可省。
else printf("%d\n",min(pre[L-][cnt-], pre[R-tmp][cnt-]));
}
return ;
}

AC代码

hihoCoder #1068 : RMQ-ST算法(模板)的更多相关文章

  1. HDU 3183 - A Magic Lamp - [RMQ][ST算法]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3183 Problem DescriptionKiki likes traveling. One day ...

  2. RMQ之ST算法模板

    #include<stdio.h> #include<string.h> #include<iostream> using namespace std; ; ],M ...

  3. 求解区间最值 - RMQ - ST 算法介绍

    解析 ST 算法是 RMQ(Range Minimum/Maximum Query)中一个很经典的算法,它天生用来求得一个区间的最值,但却不能维护最值,也就是说,过程中不能改变区间中的某个元素的值.O ...

  4. [POJ3264]Balanced Lineup(RMQ, ST算法)

    题目链接:http://poj.org/problem?id=3264 典型RMQ,这道题被我鞭尸了三遍也是醉了…这回用新学的st算法. st算法本身是一个区间dp,利用的性质就是相邻两个区间的最值的 ...

  5. 【原创】RMQ - ST算法详解

    ST算法: ID数组下标: 1   2   3   4   5   6   7   8   9    ID数组元素: 5   7   3   1   4   8   2   9   8 1.ST算法作 ...

  6. POJ 3264 Balanced Lineup RMQ ST算法

    题意:有n头牛,编号从1到n,每头牛的身高已知.现有q次询问,每次询问给出a,b两个数.要求给出编号在a与b之间牛身高的最大值与最小值之差. 思路:标准的RMQ问题. RMQ问题是求给定区间内的最值问 ...

  7. 关于基础RMQ——ST算法

    RMQ,Range Maximum/Minimum Query,顾名思义,就是询问某个区间内的最大值或最小值,今天我主要记录的是其求解方法--ST算法 相对于线段树,它的运行速度会快很多,可以做到O( ...

  8. RMQ st算法 区间最值模板

    #include<bits/stdc++.h> ; ; int f[N][Logn],a[N],lg[N],n,m; int main(){ cin>>n>>m; ...

  9. rmq的st算法模板题 nyoj 119

    士兵杀敌(三) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5 描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进行比 ...

  10. POJ 3368 Frequent values RMQ ST算法/线段树

                                                         Frequent values Time Limit: 2000MS   Memory Lim ...

随机推荐

  1. eclipse编辑窗口不见了(打开左边的java、xml文件,中间不会显示代码)

    转自:https://blog.csdn.net/u012062810/article/details/46729779?utm_source=blogxgwz4 1. windows-->re ...

  2. Eclipse安装反编译插件,查看.class文件的源码

    2017-08-24 这样我们就可以通过Eclipse查看.class文件的源码了. 1.参考别人的博客,亲测有效 https://www.cnblogs.com/JealousGirl/p/setu ...

  3. msq 表操作与其数据类型

    一:表介绍 表相当于文件, 表中的一条记录就相当于文件的一行内容, 不同的是,表中的一条记录有对应的标题,称为表的字段: id,name, age, sex,称为字段, 其余的一行内容称为一条记录. ...

  4. mysql 自动备份命令

    --1.全备 --single-transaction:基于此选项能实现热备InnoDB表  --databases要备份的表名mysqldump -u root -p --single-transa ...

  5. (Android)截图批处理

    新建一个批处理文件 输入下面的内容 @echo off rem set name=%,%%,%%,%%,%%,%%,% //设置截图文件名称 set screenShotName=%,%%,%%,% ...

  6. Spring Boot 创建自定义的properties文件

    以IDEA2018为例,在资源文件夹上点击鼠标右键,依次选择 New -> Resource Bundle ,如下图: 在弹出的对话框中,填写properties文件的名称(不用填写.prope ...

  7. unity3d easytouch教程

    http://www.taikr.com/group/6/thread/1987 说一说easytouch的简单使用方法,和移动平台上的rpg游戏一样,我们肯定也不陌生,我们经常玩游戏的时候用的都是虚 ...

  8. OPENGL3_基本图元

    类型 说明 GL_POINTS 单个顶点集 GL_LINES 多组双顶点线段 GL_POLYGON 单个简单填充凸多边形 GL_TRAINGLES 多组独立填充三角形 GL_QUADS 多组独立填充四 ...

  9. uoj#282. 长度测量鸡(构造)

    传送门 打表题--只有\(n\leq 3\)有解否则无解→_→ 或者严格证明的话是这样,因为算上端点一共\(n+1\)个点,共\(\frac{n(n+1)}{2}\)个点对,所以点对之间两两距离不相等 ...

  10. jave 计算音视频时长

    File source = new File("视频.mp4"); Encoder encoder = new Encoder(); try { MultimediaInfo in ...