news 2026/6/30 13:43:33

再谈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/7/1 4:28:05

【限时掌握】Docker Scout AI漏洞检测功能全解析,错过再等一年

第一章&#xff1a;Docker Scout AI漏洞检测技术概述Docker Scout 是 Docker 官方推出的一项智能安全分析工具&#xff0c;旨在帮助开发者和运维团队在容器生命周期早期识别镜像中的已知漏洞、配置缺陷和软件供应链风险。其核心能力之一是集成 AI 驱动的漏洞分析引擎&#xff0…

作者头像 李华
网站建设 2026/6/26 14:18:02

Wan2.2-T2V-A14B能否生成微观世界放大动画?生物学教学辅助

Wan2.2-T2V-A14B能否生成微观世界放大动画&#xff1f;生物学教学辅助 在中学生物课堂上&#xff0c;老师指着投影屏说&#xff1a;“现在我们来看一下细胞有丝分裂的过程。”画面里&#xff0c;一个圆润的细胞核缓缓裂开&#xff0c;染色体像被无形之手牵引着分离——但仔细一…

作者头像 李华
网站建设 2026/6/26 22:32:17

zabbix

文章目录zabbixzabbix介绍当前支持版本生命周期Zabbix概述zabbix架构搭建LNMP架构安装nginx先测试nginx环境安装mariad配置yum源连接数据库测试安装php配置nginx支持php配置php测试测试php首页测试连接数据库zabbix-server**导入数据库**安装软件包修改zabbix-server配置文件被…

作者头像 李华
网站建设 2026/6/29 4:23:37

万亿DeFi市场的“暗物质”:模块化组件如何重构金融底层

引言&#xff1a;当DeFi进入“乐高时代”2023年&#xff0c;DeFi&#xff08;去中心化金融&#xff09;总锁仓量&#xff08;TVL&#xff09;突破800亿美元&#xff0c;但繁荣背后隐藏着开发效率的困境&#xff1a;重复造轮子&#xff1a;每个借贷协议需独立开发利率模型、清算…

作者头像 李华
网站建设 2026/7/1 3:54:26

Kadane 算法详解:求最大连续子数组和

Kadane 算法用来在线性时间内求「最大连续子数组和」,本质是一个一维动态规划 / 滚动数组优化思路。csdn+1​ 通用思路 定义状态:设 c u r cur cur 表示「以当前位置结尾的最大连续子数组和」,设 b e s t best best 表示「目前为止见过的最大子数组和」。csdn+1​ 转移…

作者头像 李华