news 2026/5/17 7:50:48

再谈ST表

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
再谈ST表

再谈 ST 表

思想:倍增。

适用范围:对于一个不可修改的序列维护区间最大/最小值询问。

时间:O ( n log ⁡ n ) O(n\log n)O(nlogn)预处理,O ( 1 ) O(1)O(1)查询。

下文以最大值为例。

预处理

状态:设f i , j f_{i,j}fi,j表示区间[ i , i + 2 j − 1 ] [i,i+2^j-1][i,i+2j1]的最大值。

那么递推式就有:
f i , j = max ⁡ { f i , j − 1 , f i + 2 j − 1 , j − 1 } f_{i,j}=\max\left\{f_{i,j-1},f_{i+2^{j-1},j-1}\right\}fi,j=max{fi,j1,fi+2j1,j1}
显然边界是f i , 0 = a i f_{i,0}=a_ifi,0=ai。其中a i a_iai是原序列。

图解:

其中第二个,区间右边界是i + 2 j − 1 + 2 j − 1 − 1 = i + 2 j − 1 i+2^{j-1}+2^{j-1}-1=i+2^j-1i+2j1+2j11=i+2j1

查询

假设查询区间为[ l , r ] [l,r][l,r]

找到max ⁡ { k ∣ 2 k < r − l + 1 ≤ 2 k + 1 } \max\left\{k\mid 2^k<r-l+1\le 2^{k+1}\right\}max{k2k<rl+12k+1}

[ l , r ] [l,r][l,r]分解为[ l , l + 2 k − 1 ] ∪ [ r − 2 k + 1 , r ] [l,l+2^k-1]\cup [r-2^k+1,r][l,l+2k1][r2k+1,r]

即从l ll开始的2 k 2^k2k个元素与r rr结尾的2 k 2^k2k个元素。

因为2 k < r − l + 1 ≤ 2 k + 1 2^k<r-l+1\le 2^{k+1}2k<rl+12k+1,所以这俩区间一定可以覆盖整个查询区间。

对于r − 2 k + 1 r-2^k+1r2k+1的解释:
r − 2 k + 1 + 2 k − 1 = r r-2^k+1+2^k-1=rr2k+1+2k1=r
所以式子就是:
max ⁡ { f l , k , f r − 2 k + 1 , k } \max\left\{f_{l,k},f_{r-2^k+1,k}\right\}max{fl,k,fr2k+1,k}
注意:ST 表是预处理完查询,所以不支持修改。

示例代码

例题:P3865 【模板】ST 表 & RMQ 问题

#include<bits/stdc++.h>usingnamespacestd;typedeflonglongljl;#defineFUP(i,x,y)for(autoi=(x);i<=(y);++i)#defineFDW(i,x,y)for(autoi=(x);i>=(y);--i)inlinevoidRd(auto&num);constintN=1e5+5,L=25;intn,m,a[N];namespaceST{intf[N][L],Lg2[N];voidBuild(){Lg2[1]=0;FUP(i,2,n)Lg2[i]=Lg2[i/2]+1;FUP(i,1,n)f[i][0]=a[i];FUP(j,1,20){FUP(i,1,n){if(i+(1<<(j-1))>n)break;f[i][j]=max(f[i][j-1],f[i+(1<<(j-1))][j-1]);}}return;}intquery(intl,intr){intlens=r-l+1;intk=Lg2[lens];returnmax(f[l][k],f[r-(1<<k)+1][k]);}}intmain(){Rd(n);Rd(m);FUP(i,1,n)Rd(a[i]);ST::Build();intl,r;while(m--){Rd(l);Rd(r);printf("%d\n",ST::query(l,r));}return0;}inlinevoidRd(auto&num){num=0;charch=getchar();boolf=0;while(ch<'0'||ch>'9'){if(ch=='-')f=1;ch=getchar();}while(ch>='0'&&ch<='9'){num=(num<<1)+(num<<3)+(ch-'0');ch=getchar();}if(f)num=-num;return;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/9 2:56:14

阿里达摩院Qwen3-VL多模态模型重磅发布:开启视觉-语言交互新纪元

在人工智能多模态交互领域&#xff0c;阿里巴巴达摩院近日正式推出新一代Qwen3-VL模型系列&#xff0c;标志着视觉-语言理解与生成技术迎来全面革新。该模型体系不仅包含40亿和80亿参数的基础密集型版本&#xff0c;更创新性地推出具备推理增强能力的Thinking版本&#xff0c;并…

作者头像 李华
网站建设 2026/5/15 1:39:08

蚂蚁数科发布AI成绩单,今年已上架百余智能体联合解决方案

“AI的真正价值不仅在于技术的先进性&#xff0c;更在于能否深入产业一线、解决实际问题。”12月11日&#xff0c;蚂蚁数科CEO赵闻飙在生态伙伴大会上的表态&#xff0c;为当下火热的AI产业锚定了务实方向。记者在现场了解到&#xff0c;这家AI to B服务商在成绩上足够惊喜&…

作者头像 李华
网站建设 2026/5/11 23:39:30

ACPI!ACPIInitialize函数分析之替换中断对象的地址

ACPI!ACPIInitialize函数分析之替换中断对象的地址//// The following two instructions set the address of current interrupt// object the the NORMAL dispatching code.//pl (PULONG)((PUCHAR)pl ((PUCHAR)&KiInterruptTemplateObject -(PUCHAR)KiInterruptTemplate…

作者头像 李华
网站建设 2026/5/10 1:16:43

【VSCode量子作业监控面板揭秘】:掌握未来开发的黑科技工具

第一章&#xff1a;VSCode量子作业监控面板揭秘VSCode 作为现代开发者的核心工具&#xff0c;其扩展能力在量子计算领域也展现出强大潜力。通过集成量子开发套件&#xff08;如 QDK&#xff09;&#xff0c;开发者可在编辑器内实时监控量子作业的执行状态&#xff0c;实现从代码…

作者头像 李华
网站建设 2026/5/11 11:01:19

SCHNEIDER BSH0702P01F2A 模块

SCHNEIDER BSH0702P01F2A 是施耐德电气&#xff08;Schneider Electric&#xff09;生产的一款工业自动化产品&#xff0c;属于其模块化 I/O 系统的一部分。该产品通常用于工业控制系统中&#xff0c;提供信号采集、处理和传输功能。主要特性型号&#xff1a;BSH0702P01F2A品牌…

作者头像 李华