在此先祝自己这个系列写的越少越好qwq(保证不超过4篇(flag已立))

考试原题:(绝壁是看完复联出的)

第一反应:线段树??不对,是st表。嗯,没错。哎,st表咋写来着??完了凉了。

结果:写暴搜的都有60分,结果我爆了0 qwq

80-->0,与键盘无缘嘤嘤嘤

好了开始说正事

ST表用来干什么的?

给定一个区间,求最值。上面那道题是典型的模板题(虽然有毒瘤数据会卡掉st表,但我们这里不讨论)

复杂度:预处理:O(nlogn),询问:O(1)

先说预处理。

st表示一个二维数组,其中st[i][j]表示区间[i,i+2^j-1]中的最值,这里我们就拿最大值举例。显然st[i][0]=a[i],因为[i,i+1-1]中只有i一个点。那么我们怎么推其他的st[i][j]呢?

我们先来看一张图

这样我们就可以推出来:st[i][j]=max(st[i][j-1],st[i+(1<<(j-1))][j-1]。为什么呢?因为i+2^(j-1)+2^(j-1)-1=i+2*(2^(j-1))-1=i+2^j-1

这样,我们就可以预处理出来所有的st[i][j]了

int st[maxn][]//一般第二维不会超过20,这里是应对毒瘤数据范围
void init()
{
for(int i=;i<=n;i++)
st[i][]=a[i];
for(int i=;(<<i)<=n;i++)//这里实际上枚举上面说的j
{for(int j=;j+(<<i)-<n;j++)
{st[j][i]=max(st[j][i-],st[j+(<<(i-))][i-]);//这里为什么j是第一维呢?这里我们max()里面变的只有第一维,所以我们要先处理第一维,才能保证后面正常进行(就是个顺序问题)
}
}
}

查询给的区间可不是卡好2^k的,所以我们应该怎么查询呢?我们第二维表示的是i+2^j-1,我们看到这里有个次方,我们可以玄学的考虑一下log。(以2为底)

这里区间的长度显然是2^j,我们已经考虑到log,那不妨对区间长度len=2^j来个log.(向下取整),设t=log(len)/log(2)向下取整,那么2^t一定<len/2。我们发现,l+2^t一定是在[l,r]的中间往右,而r-2^t一定在中间往左。[l,l+2^t-1]与[r-2^t+1,r]这两个区间是可以完全覆盖[l,r],而且还不会有超出[l,r]的部分,所以我们就可以从st[l][t]和st[r-2^t+1][t]中选一个最大值。

Update


由于窝之前的代码是手糊的,所以出了锅。误导了您真的十分十分抱歉(我发4再也不手糊代码了qwq)

真·能AC板子的代码:

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<algorithm>
#include<vector>
#include<queue>
#include<map>
#define pa pair<int,int>
#include<ctime>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const int inf=;
inline ll read()
{
char ch=getchar();
ll x=;
bool f=;
while(ch<''||ch>'')
{
if(ch=='-') f=;
ch=getchar();
}
while(ch>=''&&ch<='')
{
x=(x<<)+(x<<)+(ch^);
ch=getchar();
}
return f?-x:x;
}
int n,m,a[],st[][];
int lg[];
int qry(int l,int r)
{
int qwq=log((double)(r-l+))/log(2.0);
return max(st[l][qwq],st[r-(<<qwq)+][qwq]);
}
int main()
{
n=read();m=read();
for(int i=;i<=n;i++)
{
a[i]=read();
st[i][]=a[i];
}
for(int i=;(<<i)<=n;i++)
{
for(int j=;j<=n;j++)
{
st[j][i]=max(st[j][i-],st[j+(<<(i-))][i-]);
}
}
while(m--)
{
int l=read(),r=read();
printf("%d\n",qry(l,r));
}
}

ST表——————一失足成千古恨系列2的更多相关文章

  1. POJ3693 Maximum repetition substring [后缀数组 ST表]

    Maximum repetition substring Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9458   Acc ...

  2. 【BZOJ-2006】超级钢琴 ST表 + 堆 (一类经典问题)

    2006: [NOI2010]超级钢琴 Time Limit: 20 Sec  Memory Limit: 552 MBSubmit: 2473  Solved: 1211[Submit][Statu ...

  3. 【BZOJ-3956】Count ST表 + 单调栈

    3956: Count Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 173  Solved: 99[Submit][Status][Discuss] ...

  4. 【BZOJ-4569】萌萌哒 ST表 + 并查集

    4569: [Scoi2016]萌萌哒 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 459  Solved: 209[Submit][Status] ...

  5. 【BZOJ-4310】跳蚤 后缀数组 + ST表 + 二分

    4310: 跳蚤 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 180  Solved: 83[Submit][Status][Discuss] De ...

  6. HDU5726 GCD(二分 + ST表)

    题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5726 Description Give you a sequence of N(N≤100, ...

  7. Hdu 5289-Assignment 贪心,ST表

    题目: http://acm.hdu.edu.cn/showproblem.php?pid=5289 Assignment Time Limit: 4000/2000 MS (Java/Others) ...

  8. Bzoj 2006: [NOI2010]超级钢琴 堆,ST表

    2006: [NOI2010]超级钢琴 Time Limit: 20 Sec  Memory Limit: 552 MBSubmit: 2222  Solved: 1082[Submit][Statu ...

  9. ST表poj3264

      /* ST表多次查询区间最小值 设 g[j][i] 表示从第 i 个数到第 i + 2 ^ j - 1 个数之间的最小值 类似DP的说 ans[i][j]=min (ans[i][mid],ans ...

随机推荐

  1. 事件驱动体系结构(EDA)

  2. 快速排序 && 寻找第K大(小)的数

    参考:https://minenet.me/2016/08/24/quickSort.html 快速排序 利用分治法可将快速排序的分为三步: 在数据集之中,选择一个元素作为"基准" ...

  3. AI会议网站

    <麻省理工科技评论>新兴科技峰会EmTech China : http://www.emtechchina.cn/ IT大咖说 各种科技前沿会议发布站 : http://www.itdks ...

  4. windows 使用nginx

    windows 安装nginx 进入此地址进行下载 http://nginx.org/en/download.html 解压到相关目录 启动 start nginx 关闭 nginx -s stop ...

  5. C#Exception 追踪异常位置

    1:在编写软件时,保护关键位置的代码正常运行,要对这位置进行异常处理try catch private void StartTCPServer() { try { ........//我们要确保知道这 ...

  6. hdu-4292.food(类dining网络流建图)

    Food Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  7. Visual Studio 2017打包安装项目

    在我们用VS编好上位机后,就可以在自己电脑运行上位机,但是想其他人电脑运行上位机可能就行不通了,因为其他人电脑不一定有所需要的运行环境.这时我们就需要打包安装,把运行软件所需要的环境都打包在安装包里. ...

  8. CentOS 5.5编译安装lnmp

    如果是安装Centos6.5记得Perl是必选的,否则无法安装VMWare Tools!!!!切记 如果出现make错误需要安装其他软件,装好后  make clean   make install ...

  9. Excel VBA批量处理寸照名字

    需求:因为处理学生学籍照片,从照相馆拿回来的寸照是按班级整理好,文件名是相机编号的文件.那么处理的话,是这么一个思路,通过Excel表格打印出各班A4照片列表,让学生自行填上照片对应姓名.表格收回来后 ...

  10. 通过利用immutability的能力编写更安全和更整洁的代码

    通过利用immutability的能力编写更安全和更整洁的代码 原文:Write safer and cleaner code by leveraging the power of "Imm ...