LOJ6277~6285 数列分块入门
分块需注意的问题
- 数组大小应为,因为最后一个块可能会超出的范围。
- 当操作的区间在一个块内时,要特判成暴力修改。
- 要清楚什么时候应该
+tag[t]
数列分块入门 1
给出一个长为的数列,以及个操作,操作涉及区间加法,单点查值。
//数列分块入门 1
#include <cstdio>
#include <cmath>
inline char gc()
{
static char now[1<<16],*S,*T;
if(S==T) {T=(S=now)+fread(now,1,1<<16,stdin); if(S==T) return EOF;}
return *S++;
}
inline int read()
{
int x=0,f=1; char ch=gc();
while(ch<'0'||'9'<ch) {if(ch=='-') f=-1; ch=gc();}
while('0'<=ch&&ch<='9') x=x*10+ch-'0',ch=gc();
return x*f;
}
int const N=5e4+10;
int n,n0;
int a[N],tag[N];
int main()
{
n=read(); n0=sqrt(n);
for(int i=1;i<=n;i++) a[i]=read();
for(int owo=1;owo<=n;owo++)
{
int opt=read(),L=read(),R=read(),c=read();
if(opt==0)
{
int L0=L/n0,R0=R/n0;
if(L0==R0) {for(int i=L;i<=R;i++) a[i]+=c; continue;}
for(int i=L;i<=(L0+1)*n0-1;i++) a[i]+=c;
for(int i=L0+1;i<=R0-1;i++) tag[i]+=c;
for(int i=R0*n0;i<=R;i++) a[i]+=c;
}
else printf("%d\n",a[R]+tag[R/n0]);
}
return 0;
}
数列分块入门 2
给出一个长为的数列,以及个操作,操作涉及区间加法,询问区间内小于某个值的元素个数。
//数列分块入门 2
#include <cstdio>
#include <cmath>
#include <algorithm>
using namespace std;
inline char gc()
{
static char now[1<<16],*S,*T;
if(S==T) {T=(S=now)+fread(now,1,1<<16,stdin); if(S==T) return EOF;}
return *S++;
}
inline int read()
{
int x=0,f=1; char ch=gc();
while(ch<'0'||'9'<ch) {if(ch=='-') f=-1; ch=gc();}
while('0'<=ch&&ch<='9') x=x*10+ch-'0',ch=gc();
return x*f;
}
int const N=5e4+1000;
int const INF=0x7FFFFFFF;
int n,n0;
int a[N],b[N],tag[N];
void update(int t)
{
int fr=t*n0,to=fr+n0-1;
for(int i=fr;i<=to;i++) b[i]=a[i];
sort(b+t*n0,b+(t+1)*n0);
}
int query(int t,int x)
{
return lower_bound(b+t*n0,b+(t+1)*n0,x)-(b+t*n0);
}
int main()
{
n=read(); n0=sqrt(n);
for(int i=1;i<=n;i++) a[i]=b[i]=read();
b[0]=INF; for(int i=n+1;i<=(n/n0+1)*n0;i++) b[i]=INF;
for(int t=0;t<=n/n0;t++) sort(b+t*n0,b+(t+1)*n0);
for(int owo=1;owo<=n;owo++)
{
int opt=read(),L=read(),R=read(),c=read();
int L0=L/n0,R0=R/n0;
if(opt==0)
{
if(L0==R0) for(int i=L;i<=R;i++) a[i]+=c;
else
{
for(int i=L;i<=(L0+1)*n0-1;i++) a[i]+=c;
for(int t=L0+1;t<=R0-1;t++) tag[t]+=c;
for(int i=R0*n0;i<=R;i++) a[i]+=c;
}
update(L0),update(R0);
}
else
{
int res=0;
if(L0==R0) for(int i=L;i<=R;i++) res+=(a[i]+tag[L0]<c*c);
else
{
for(int i=L;i<=(L0+1)*n0-1;i++) res+=(a[i]+tag[L0]<c*c);
for(int t=L0+1;t<=R0-1;t++) res+=query(t,c*c-tag[t]);
for(int i=R0*n0;i<=R;i++) res+=(a[i]+tag[R0]<c*c);
}
printf("%d\n",res);
}
}
return 0;
}
数列分块入门 3
给出一个长为的数列,以及个操作,操作涉及区间加法,询问区间内小于某个值的前驱(比其小的最大元素)。
//数列分块入门 3
#include <cstdio>
#include <cmath>
#include <algorithm>
using namespace std;
inline char gc()
{
static char now[1<<16],*S,*T;
if(S==T) {T=(S=now)+fread(now,1,1<<16,stdin); if(S==T) return EOF;}
return *S++;
}
inline int read()
{
int x=0,f=1; char ch=gc();
while(ch<'0'||'9'<ch) {if(ch=='-') f=-1; ch=gc();}
while('0'<=ch&&ch<='9') x=x*10+ch-'0',ch=gc();
return x*f;
}
int const N=1e5+1000;
int const INF=0x7FFFFFFF;
int n,n0;
int a[N],b[N],tag[N];
void update(int t)
{
int fr=t*n0,to=fr+n0;
for(int i=fr;i<to;i++) b[i]=a[i];
sort(b+fr,b+to);
}
int res;
void check(int x,int x0) {if(x<x0) res=max(res,x);}
int pre(int t,int v)
{
int x=lower_bound(b+t*n0,b+t*n0+n0,v)-b;
return x==t*n0?-INF:b[x-1]+tag[t];
}
int main()
{
n=read(); n0=sqrt(n);
for(int i=1;i<=n;i++) a[i]=b[i]=read();
b[0]=INF; for(int i=n+1;i<=n/n0*n0;i++) b[i]=INF;
for(int t=0;t<=n/n0;t++) sort(b+t*n0,b+t*n0+n0);
for(int owo=1;owo<=n;owo++)
{
int opt=read(),L=read(),R=read(),c=read();
int L0=L/n0,R0=R/n0;
if(opt==0)
{
if(L0==R0) for(int i=L;i<=R;i++) a[i]+=c;
else
{
for(int i=L;i<=(L0+1)*n0-1;i++) a[i]+=c;
for(int t=L0+1;t<=R0-1;t++) tag[t]+=c;
for(int i=R0*n0;i<=R;i++) a[i]+=c;
}
update(L0),update(R0);
}
else
{
res=-INF;
if(L0==R0)
for(int i=L;i<=R;i++) check(a[i]+tag[L0],c);
else
{
for(int i=L;i<=(L0+1)*n0-1;i++) check(a[i]+tag[L0],c);
for(int t=L0+1;t<=R0-1;t++) res=max(res,pre(t,c-tag[t]));
for(int i=R0*n0;i<=R;i++) check(a[i]+tag[R0],c);
}
printf("%d\n",res>-INF?res:-1);
}
}
return 0;
}LOJ6277~6285 数列分块入门的更多相关文章
- LOJ #6285. 数列分块入门 9-分块(查询区间的最小众数)
#6285. 数列分块入门 9 内存限制:256 MiB时间限制:1500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 2 题目描述 给 ...
- 题解【loj6277】数列分块入门1
题目描述 给出一个长为\(n\)的数列,以及\(n\)个操作,操作涉及区间加法,单点查值. 输入格式 第一行输入一个数字\(n\). 第二行输入\(n\)个数字,第\(i\)个数字为\(a_{i}\) ...
- loj#6285 数列分块入门 9 ( 回 滚 )
题目 : 链接 :https://loj.ac/problem/6285 题意:给出一个长为 n的数列,以及 n个操作,操作涉及询问区间的最小众数. 思路:虽然这不是一道 回滚莫队题,就是 暴力分块 ...
- LibreOJ 6285. 数列分块入门 9
题目链接:https://loj.ac/problem/6285 其实一看到是离线,我就想用莫队算法来做,对所有询问进行分块,但是左右边界移动的时候,不会同时更新数字最多的数,只是后面线性的扫了一遍, ...
- LOJ#6285. 数列分块入门 9
有点难..... 要求区间众数,所以我可以先把区间分块,然后我预处理出从第 i 块到第 j 块的众数,用dp[i][j]记录下来. 因为需要知道众数的num值, 所以我可以用一个vector来保存每个 ...
- 数列分块入门九题(三):LOJ6283~6285
Preface 最后一题我一直觉得用莫队是最好的. 数列分块入门 7--区间乘法,区间加法,单点询问 还是很简单的吧,比起数列分块入门 7就多了个区间乘. 类似于线段树,由于乘法的优先级高于加法,因此 ...
- 数列分块入门九题(一):LOJ6277~6279
Preface 分块,一个神奇的暴力算法.可以把很多\(O(n^2)\)的数据结构题的暴力优化到常数极小的\(O(n\sqrt n)\).当一些毒瘤题无法用线段树,主席树,平衡树,树状数组...... ...
- [Loj] 数列分块入门 1 - 9
数列分块入门 1 https://loj.ac/problem/6277 区间加 + 单点查询 #include <iostream> #include <cstdio> #i ...
- 数列分块入门九题(二):LOJ6280~6282
Preface 个人感觉这中间的三题是最水的没有之一 数列分块入门 4--区间加法,区间求和 这个也是很多数据结构完爆的题目线段树入门题,但是练分块我们就要写吗 修改还是与之前类似,只不过我们要维护每 ...
随机推荐
- Servlet--ServletInputStream类,ServletOutputStream类
ServletInputStream类 定义 public abstract class ServletInputStream extends InputStream 这个类定义了一个用来读取客户端的 ...
- 关于oracle视图小结
关于oracle的视图小记:一. 视图:就是对SQL语句的封装,使用起来更方便.不易出错 优点: 1.简化数据操作:视图可以简化用户处理数据的方式 2.着重于特定数据:不必要的数据或敏感的数据可以 不 ...
- maven的聚合和继承
Maven的聚合特性能够把项目的各个模块聚合在一起构建: 而Maven的继承特性则能帮组抽取各模块相同的依赖和插件等配置,在简化POM的同时,还能促进各个模块配置的一致性. 聚合:新建一个项目demo ...
- Part 4:表单和类视图--Django从入门到精通系列教程
该系列教程系个人原创,并完整发布在个人官网刘江的博客和教程 所有转载本文者,需在顶部显著位置注明原作者及www.liujiangblog.com官网地址. Python及Django学习QQ群:453 ...
- 爬取西刺网的免费IP
在写爬虫时,经常需要切换IP,所以很有必要自已在数据维护库中维护一个IP池,这样,就可以在需用的时候随机切换IP,我的方法是爬取西刺网的免费IP,存入数据库中,然后在scrapy 工程中加入tools ...
- 从UUID想到的
1.UUID的定义 通用唯一标识符(UUID)被设计成一个在时间和空间上都独一无二的数字,常被用作唯一性标识. UUID是一个由5位十六进制数的字符串表示的128比特数字,其格式为 aaaaaaaa- ...
- HDU 4333 Revolving Digits [扩展KMP]【学习笔记】
题意:给一个数字,每一次把它的最后一位拿到最前面,一直那样下去,分别求形成的数字小于,等于和大于原来数的个数. SAM乱搞失败 当然要先变SS了 然后考虑每个后缀前长为n个字符,把它跟S比较就行了 如 ...
- SDN第二次上机作业
作业链接 安装floodlight 生成拓扑并连接控制器floodlight,利用控制器floodlight查看图形拓扑 from mininet.topo import Topo class MyT ...
- Vue中结合Flask与Node.JS的异步加载功能实现文章的分页效果
你好!欢迎阅读我的博文,你可以跳转到我的个人博客网站,会有更好的排版效果和功能. 此外,本篇博文为本人Pushy原创,如需转载请注明出处:http://blog.pushy.site/posts/15 ...
- crontab定时任务一定要记得做好备份
今天咋服务器上敲了一个 crontab 命令(没加-e ,也没加-l, 更没加 -r) 但是竟然神奇的crontab全部被清除了. 心中一万只CN