news 2026/6/15 17:03:03

再谈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/6/15 14:58:15

Wan2.2-T2V-A14B模型轻量化部署方案探索与实践

Wan2.2-T2V-A14B模型轻量化部署方案探索与实践 在影视级AI内容生成逐渐从“能用”迈向“好用”的今天&#xff0c;一个现实问题正摆在开发者面前&#xff1a;那些动辄百亿参数的文本到视频&#xff08;T2V&#xff09;大模型&#xff0c;如何走出实验室&#xff0c;在真实业务场…

作者头像 李华
网站建设 2026/6/15 13:32:15

Wan2.2-T2V-A14B在动漫IP衍生内容生产中的商业模式

Wan2.2-T2V-A14B在动漫IP衍生内容生产中的商业模式从“周更”到“秒出”&#xff1a;AI如何重塑动漫内容生产节奏 你有没有想过&#xff0c;一个动画角色今天穿什么衣服、说什么话&#xff0c;明天就能出现在短视频里向全球粉丝拜年&#xff1f;这在过去需要数周甚至数月的美术…

作者头像 李华
网站建设 2026/6/15 14:38:54

2025-12-12:升级后最大生成树稳定性。用go语言,给出一个包含编号 0 到 n-1 的 n 个节点的无向图,边的列表 edges 中每条记录为 [ui, vi, si, musti],含义如下

2025-12-12&#xff1a;升级后最大生成树稳定性。用go语言&#xff0c;给出一个包含编号 0 到 n-1 的 n 个节点的无向图&#xff0c;边的列表 edges 中每条记录为 [ui, vi, si, musti]&#xff0c;含义如下&#xff1a;ui、vi&#xff1a;该条边连接的两个端点&#xff08;无向…

作者头像 李华
网站建设 2026/6/15 15:37:30

HCIA-AI V4.0 H13-311题库练习题(带详细解析)

继续分享HCIA-AI 4.0的题库练习题&#xff0c;完整的题库我已经发在题主小程序上了&#xff0c;需要的可以自己去找。以下关于梯度下降法的描述错误的是哪些项?A. 负梯度方向是函数下降最快的方向B. 梯度下降法一定够在凸优化问题中取得全局极值点C. 梯度下降法不一定能够在凸…

作者头像 李华
网站建设 2026/6/14 14:24:53

Wan2.2-T2V-A14B支持生成多视角视频吗?360°全景内容设想

Wan2.2-T2V-A14B支持生成多视角视频吗&#xff1f;360全景内容设想 在影视预演、虚拟现实和元宇宙内容爆发的今天&#xff0c;创作者面临一个共同难题&#xff1a;如何以低成本快速构建高保真、空间一致的动态视觉资产&#xff1f;传统拍摄依赖复杂布景与多机位协同&#xff0c…

作者头像 李华