ST表 & RMQ问题

ST表

主要用来解决RMQ(区间最大/最小值查询)问题,主要应用倍增思想,可以实现O(n log n)预处理,O(1)查询。

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

代码:

cpp 复制代码
//P3865 【模板】ST 表 & RMQ 问题
#include<bits/stdc++.h>
using namespace std;
#define int long long
#define ull unsigned long long
#define i128 __int128_t
#define INF -1e18
#define ls(x) x<<1
#define rs(x) x<<1|1
#define pii pair<int,int>
#define lowbit(x) ((x)&-(x))
#define IOS ios::sync_with_stdio(false),cin.tie(nullptr),cout.tie(nullptr)
#define fi first
#define se second
#define endl '\n' 
typedef long long ll;
const int N=1e5+5;
const int M=1000000;
const int MOD=1e9+7;
const int maxk=22;

const int LOG=log2(N)+1;

int f[N][LOG];
int n,m;

void solve(){
    cin>>n>>m;
    for(int i=1;i<=n;i++) cin>>f[i][0];
    for(int i=1;i<=LOG;i++){ //枚举区间长度的指数
        for(int j=1;j+(1LL<<i)-1<=n;j++){ //枚举起点
            f[j][i]=max(f[j][i-1],f[j+(1LL<<(i-1))][i-1]);
        }
    }

    int l,r;
    while(m--){
        cin>>l>>r;
        int k=log2(r-l+1); //区间长度的指数
        cout<<max(f[l][k],f[r-(1LL<<k)+1][k])<<endl;
    }
}

signed main(){
    IOS;
    int T=1;
    //cin>>T;
    while(T--){
        solve();
    }

    return 0;
}
相关推荐
帅小伙―苏3 分钟前
力扣76最小覆盖子串
算法·leetcode
RH23121112 分钟前
2026.5.24 数据结构 KMP算法实现
数据结构·算法
江屿风15 分钟前
C++图论基础单源最短路-常规版dijkstra算法/堆优化版dijkstra算法/bellman-ford 算法/spfa 算法流食般投喂
开发语言·c++·笔记·算法·图论
浮芷.29 分钟前
鸿蒙 6.1 新特性-60fps流畅人物跳跃功能算法深度解析-鸿蒙PC端正弦值计算法
算法·华为·harmonyos·鸿蒙·鸿蒙系统
AI科技星32 分钟前
数术工坊·第八卷 大道归一录・番外・下篇 零界封神・万法归元终章
网络·人工智能·算法·几何学·拓扑学
Misnearch37 分钟前
Leetcode热题100
算法·leetcode·职场和发展
我是一颗柠檬1 小时前
【Java项目技术亮点】滑动窗口限流算法
java·开发语言·算法
无限码力1 小时前
华为非AI方向笔试真题 - 楼内救人
算法·华为·华为非ai方向笔试真题·华为笔试真题·华为算法题
一切皆是因缘际会1 小时前
隐层表征解构:LLM感知式幻觉稀疏成因
算法·数学建模·ai·架构
Irissgwe1 小时前
二叉树进阶
数据结构·c++·算法·c·二叉搜索树