刷题总结——教主的魔法(bzoj3343)
题目:
Description
Input
Output
Sample Input
1 2 3 4 5
A 1 5 4
M 3 5 1
A 1 5 4
Sample Output
3
HINT
Source
题解:
引用hwzer题解,%%%%%%%%%%:
就是每一块的个数为根号n
修改:
对于一整块,直接打add标记
头尾俩块不完整的进行暴力修改重构
查询
每一块内排序,在第i块内二分查找大等于C-add[i]的数字
头尾俩块暴力查询
自己再说些吧··以前写的都是空间为n√n的,这道题肯定不行,新学了一种利用二分节约空间的分块(虽然时间复杂度为n√n logn)
代码:
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<ctime>
#include<cctype>
#include<cstring>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=1e6+;
const int M=1e3+;
int n,id[N],b[N],a[N],tots,s,Right[M],Left[M],add[M],m;
bool jud[N];
inline int R()
{
char c;int f=;
for(c=getchar();c<''||c>'';c=getchar());
for(;c<=''&&c>='';c=getchar())
f=(f<<)+(f<<)+c-'';
return f;
}
inline void update(int now)
{
for(int i=Left[now];i<=Right[now];i++) b[i]=a[i];
sort(b+Left[now],b+Right[now]+);
}
inline int find(int x,int w)
{
int l=Left[x],r=Right[x],ans=;
while(l<=r)
{
int mid=(l+r)/;
if(b[mid]>=w) ans=mid,r=mid-;
else l=mid+;
}
if(!ans) return ;
else return Right[x]-ans+;
}
inline void modify(int l,int r,int c)
{
if(r-l+<*s)
{
for(int i=l;i<=r;i++)
a[i]+=c;
update(id[l]),update(id[r]);
}
else
{
int lefts,rights;
if(l%s==) lefts=id[l];
else lefts=id[l]+;
if(jud[r]) rights=id[r];
else rights=id[r]-;
for(int i=l;i<Left[lefts];i++) a[i]+=c;
for(int i=Right[rights]+;i<=r;i++) a[i]+=c;
for(int i=lefts;i<=rights;i++) add[i]+=c;
update(id[l]),update(id[r]);
}
return;
}
inline int getans(int l,int r,int c)
{
int ans=;
if(r-l+<*s)
{
for(int i=l;i<=r;i++)
if(a[i]+add[id[i]]>=c) ans++;
return ans;
}
else
{
int lefts,rights;
if(l%==) lefts=id[l];
else lefts=id[l]+;
if(jud[r]) rights=id[r];
else rights=id[r]-;
for(int i=l;i<Left[lefts];i++)
if(a[i]+add[id[i]]>=c) ans++;
for(int i=Right[rights]+;i<=r;i++)
if(a[i]+add[id[i]]>=c) ans++;
for(int i=lefts;i<=rights;i++)
ans+=find(i,c-add[i]);
return ans;
}
} int main()
{
//freopen("a.in","r",stdin);
n=R(),m=R();s=(int)sqrt(n);
for(int i=;i<=n;i++) a[i]=R();
for(int i=;i<=n;i++)
{
if(i%s==) id[i]=++tots,Left[tots]=i;
else if(i%s==) id[i]=tots,Right[tots]=i,jud[i]=true;
else id[i]=tots;
}
Right[tots]=n,jud[n]=true;
for(int i=;i<=tots;i++) update(i);
int l,r,w;
char s[];
while(m--)
{
scanf("%s",s);
l=R(),r=R(),w=R();
if(s[]=='M')
modify(l,r,w);
else
printf("%d\n",getans(l,r,w));
}
return ;
}
刷题总结——教主的魔法(bzoj3343)的更多相关文章
- [BZOJ3343]教主的魔法
[BZOJ3343]教主的魔法 试题描述 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了一起,这次他们排成了一列,被编号为1.2.… ...
- 【BZOJ-3343】教主的魔法 分块
3343: 教主的魔法 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 950 Solved: 414[Submit][Status][Discuss ...
- BZOJ3343: 教主的魔法 分块
2016-05-28 10:27:19 题目:http://www.lydsy.com/JudgeOnline/problem.php?id=3343 比较显然的分块题,分块后块内排序,维护整块的附 ...
- 【bzoj3343】教主的魔法 分块
[bzoj3343]教主的魔法 2014年4月26日8092 Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了 ...
- c++之路进阶——bzoj3343(教主的魔法)
F.A.Qs Home Discuss ProblemSet Status Ranklist Contest ModifyUser gryz2016 Logout 捐赠本站 Notice:由于本OJ ...
- Luogu 2801 教主的魔法 | 分块模板题
Luogu 2801 教主的魔法 | 分块模板题 我犯的错误: 有一处l打成了1,还看不出来-- 缩小块大小De完bug后忘了把块大小改回去就提交--还以为自己一定能A了-- #include < ...
- 【BZOJ3343】教主的魔法 分块+二分
Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了一起,这次他们排成了一列,被编号为1.2.…….N. 每个人的 ...
- 【分块】bzoj3343: 教主的魔法
3343: 教主的魔法 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 631 Solved: 272[Submit][Status][Discuss ...
- BZOJ3343 & 洛谷2801:教主的魔法——题解
http://www.lydsy.com/JudgeOnline/problem.php?id=3343 https://www.luogu.org/problemnew/show/2801 题目描述 ...
随机推荐
- MD5 介绍
MD5(单向散列算法)的全称是Message-Digest Algorithm 5(信息-摘要算法),经MD2.MD3和MD4发展而来.MD5算法的使用不需要支付任何版权费用. MD5功能: 输入任意 ...
- Hadoop集群_VSFTP安装配置
原作者写的太好了,我这个菜鸟不自觉就转载了,原文链接:http://www.cnblogs.com/xia520pi/archive/2012/05/16/2503864.html 如果,您认为阅读这 ...
- threadLocal遇上线程池导致局部变量变化
这两天一直在查无线app一个诡异的问题,表象是stg的接口返回数据,和线上接口的返回数据不一致. 1.初步判断:有缓存,查看代码后发现缓存时间直邮6分钟,而且同一个接口,其他调用方的返回数据,stg和 ...
- vijos 1034 家族(水题日常)
描述 若某个家族人员过于庞大,要判断两个是否是亲戚,确实还很不容易,现在给出某个亲戚关系图,求任意给出的两个人是否具有亲戚关系. 规定:x和y是亲戚,y和z是亲戚,那么x和z也是亲戚.如果x,y是亲戚 ...
- (三)mybatis之对Hibernate初了解
前言:为什么会写Hibernate呢?因为HIbernate跟Mybatis一样,是以ORM模型为核心思想的,但是这两者有相似的地方也有差异的地方.通过这两种框架的比对,可以对mybatis有着更深的 ...
- 迅为IMX6Q开发板在道路交通信号控制系统解决方案中的应用
智能交通综合管控平台是为交通指挥系统服务的统一信息平台,以信息技术为主导,以计算机通信网络和智能化指挥控制管理为基础,建成集高新技术应用为一体的智能化指挥调度集成平台,实现信息交换与共享.快速反应决策 ...
- (转)MyBatis框架的学习(二)——MyBatis架构与入门
http://blog.csdn.net/yerenyuan_pku/article/details/71699515 MyBatis框架的架构 MyBatis框架的架构如下图: 下面作简要概述: S ...
- spark 的RDD各种转换和动作
今天先把spark的各种基本转换和动作总结下,以后有时间把各种用法放上去. 1 RDD基本转换操作 map.flagMap.distinct coalesce.repartition coale ...
- python打开.pkl的文件并显示里面的内容
pkl文件是pyhthon里面保存文件的一种格式,如果直接打开会显示一堆序列化的东西.正确的打开方式如下: import cPickle as pickle f = open('path') info ...
- Spring启动流程—源码解读
https://blog.csdn.net/yangliuhbhd/article/details/80790761 Spring的AbstractApplicationContext的refresh ...