BZOJ5042: LWD的分科岛
2024-08-31 14:40:13
【传送门:BZOJ5042】
简要题意:
给出n个数,q个询问,每个询问输入opt,l,r,如果opt=1,则输出l到r中的最小值,否则输出最大值
题解:
直接上ST表,自信一波,结果
MLE??好吧,离线求,最大最小值用一个数组求
TLE???好吧,看讨论,询问的范围1000左右,好,缩一波时间
RE????好吧,不预处理2的次方,直接位运算
AC??好吧,ok了
参考代码:
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<cmath>
using namespace std;
inline int read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-') f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
int m[][];
int Log[];
struct question
{
int l,r,opt,d;
}q[];
int main()
{int n=read(),Q=read();
for(int i=;i<=n;i++)
{
int x=read();
m[][i]=x;
}
Log[]=-;for(int i=;i<=n;i++) Log[i]=Log[i>>]+;
for(int i=;(<<i)<=n&&i<=;i++)
{
for(int j=;j<=n;j++)
{
if(j+(<<i)-<=n)
{
m[i][j]=min(m[i-][j],m[i-][j+(<<(i-))]);
}
else break;
}
}
for(int i=;i<=Q;i++) q[i].opt=read(),q[i].l=read(),q[i].r=read();
for(int i=;i<=Q;i++)
{
int opt=q[i].opt,l=q[i].l,r=q[i].r;
if(q[i].opt==)
{
int t=Log[r-l+];
q[i].d=min(m[t][l],m[t][r-(<<t)+]);
}
}
for(int i=;(<<i)<=n&&i<=;i++)
{
for(int j=;j<=n;j++)
{
if(j+(<<i)-<=n)
{
m[i][j]=max(m[i-][j],m[i-][j+(<<(i-))]);
}
else break;
}
}
for(int i=;i<=Q;i++)
{
int opt=q[i].opt,l=q[i].l,r=q[i].r;
if(q[i].opt==)
{
int t=Log[r-l+];
q[i].d=max(m[t][l],m[t][r-(<<t)+]);
}
}
for(int i=;i<=Q;i++) printf("%d\n",q[i].d);
return ;
}
最新文章
- 关于目录路径path
- 深入理解脚本化CSS系列第四篇——脚本化样式表
- Java的数据类型
- 使用原生JS封装Ajax
- 关于页面滚动值scrollTop在FireFox与Chrome浏览器间的兼容问题
- 新建maven项目
- Quartz集群原理及配置应用
- 新注册域名greenopen.site,向专业道路进军
- 【在线】Actionbar Style Generator:ActionBar风格生成器
- 从四大音乐APP首页设计对比分析产品方向
- Emacs golang 配置
- java中的容器问题
- Ubuntu12.10编译openwrt遇到的错误
- Objective-C 获取当前执行函数的名称
- Linux模式设计系列( 内核与应用关联思考)
- C语言基础学习学习前的准备-2
- Linux学习笔记——如何使用共享库交叉编译
- AXI_DMA IP学习
- 潭州课堂25班:Ph201805201 django框架 第十课 GET,POST 请求 文件上传,HttpResponse,cookie (课堂笔记)
- [Aaronyang] 写给自己的WPF4.5 笔记9[复杂数据处理三步曲,数据展示ListView泪奔2/3]