洛谷P3865 -【模板】ST表 - RMQ模板题 - ST算法
题目链接
https://www.luogu.com.cn/problem/P3865
适用范围
主要是处理区间最值问题。
时间复杂度
的时间内进行预处理,的时间进行查询。(线段树解决可能会超时)
即列数:最大是(计算机上默认以log以2为底),
也就是如果以一个表格形式呈现的话,那么行数为,列数为。
本题的f数组列数开17就行,因为。
算法分析
ST算法是在线处理RMQ的算法,是一个DP思想,但是状态转移方程是从前面已知的一列转移过来,和背包有所不同。
主要思想就是:分治、倍增、动规。
数组表示的是:从第个数起连续个数中的最大值。(个数包括第个数)
学习链接
https://www.bilibili.com/video/BV1pE411u7Gq?from=search&seid=10536624648902837005
注意
本题scanf输入会有一组数据TLE,所以建议快读。
AC代码
#include<bits/stdc++.h>
using namespace std;
const int N=1e5+20;
inline int read()
{
int x=0,f=1;char ch=getchar();
while (!isdigit(ch)){if (ch=='-') f=-1;ch=getchar();}
while (isdigit(ch)){x=x*10+ch-48;ch=getchar();}
return x*f;
}
int f[N][21];
int main()
{
int n=read(),m=read(); // 序列长度 询问次数
for(int i=1;i<=n;i++)
{
f[i][0]=read(); // 初始化f数组,画一个图可以得出这个结论
}
int x=(int)(log(n)/log(2));
for(int j=1;j<=x;j++)
{
int w=n-(1<<j)+1;
for(int i=1;i<=w;i++)
f[i][j]=max(f[i][j-1],f[i+(1<<(j-1))][j-1]);
}
for(int i=1;i<=m;i++)
{
int l=read(),r=read();
int w=(int)(log(r-l+1)/log(2));
printf("%d\n",max(f[l][w],f[r-(1<<w)+1][w])); // 别忘了+1
}
return 0;
}
分类:
数论
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」