数据结构·ST表

ST表(Sparse Table)

可重复贡献问题

  • x o p t x = x x \ opt\ x = x x opt x=x :如果两个区间重复计算某些元素时,对重复元素 进行 o p t opt opt操作没有任何影响

理解

ST表的思想是倍增,每一次处理上一次处理的两倍的元素 ,倍增的方式有重叠部分,如果重叠部分可重复贡献,则倍增的思路是正确的。

  • 长度:int len=log2(n),向下取整,避免出现无效元素参与计算
  • 构造时的递推公式:amax[j][m] = max(amax[j - 1][m], amax[j - 1][m + (1 << j - 1)]),例子:第3层第1个元素,由第2层第1,2,3个元素累积得到,其中第二个元素出现重复。
  • query:max(amax[len][l], amax[len][r - (1 << len) + 1]),首先查询当前层l处的元素,然后考虑当前层代表了 2 l e n 2^{len} 2len个元素,由第一层元素反推第len层元素。

模板

  • init()操作: O ( n l o g n ) O(nlogn) O(nlogn)复杂度
cpp 复制代码
		int len = log2(n);
		for (int j = 1; j <= len; j++) {
			for (int m = 1; m <= n - (1 << j) + 1; m++) {
				amax[j][m] = max(amax[j - 1][m], amax[j - 1][m + (1 << j - 1)]);
				amin[j][m] = min(amin[j - 1][m], amin[j - 1][m + (1 << j - 1)]);
			}
		}
  • query()操作: O ( 1 ) O(1) O(1),仅仅支持静态查询,不支持任意修改方式
cpp 复制代码
int query(int l,int r,int flag) {//flag==1 max
	int len = log2(r - l + 1);
	if (flag)return max(amax[len][l], amax[len][r - (1 << len) + 1]);
	return min(amax[len][l], amax[len][r - (1 << len) + 1]);
}
  • 优化:log2操作比较费时,所以可以采用dp方式优化该运算。
cpp 复制代码
lg[0]=-1;
for(int i=1;i<=n;i++)lg[i]=lg[i>>1]+1;

例题

P7333 [JRKSJ R1] JFCA:环的处理,二分的选择。

P10059 Choose:二分,注意到当L=n-k+1时,就能取到X的最大值,且L的取值与取到X的最大值有单调关系,使用二分。

相关推荐
晨晖21 小时前
单链表逆转,c语言
c语言·数据结构·算法
其美杰布-富贵-李3 小时前
HDF5文件学习笔记
数据结构·笔记·学习
明洞日记4 小时前
【数据结构手册008】STL容器完全参考指南
开发语言·数据结构·c++
kingmax542120085 小时前
《数据结构C语言:单向链表-链表基本操作(尾插法建表、插入)》15分钟试讲教案【模版】
c语言·数据结构·链表
AI科技星5 小时前
质量定义方程常数k = 4π m_p的来源、推导与意义
服务器·数据结构·人工智能·科技·算法·机器学习·生活
Fine姐5 小时前
数据结构04——二叉树搜索树BST
数据结构
仰泳的熊猫6 小时前
1077 Kuchiguse
数据结构·c++·算法·pat考试
阿里巴巴AI编程社区6 小时前
Qoder 提效实战:数据开发工程师用 Qoder 提效50%
数据结构
消失的旧时光-19436 小时前
从 C 链表到 Android Looper:MessageQueue 的底层原理一条线讲透
android·数据结构·链表
夏乌_Wx6 小时前
练题100天——DAY28:找消失的数字+分发饼干
数据结构·算法