题目:

Description

教主最近学会了一种神奇的魔法,能够使人长高。于是他准备演示给XMYZ信息组每个英雄看。于是N个英雄们又一次聚集在了一起,这次他们排成了一列,被编号为1、2、……、N
每个人的身高一开始都是不超过1000的正整数。教主的魔法每次可以把闭区间[LR](1≤LRN)内的英雄的身高全部加上一个整数W。(虽然L=R时并不符合区间的书写规范,但我们可以认为是单独增加第LR)个英雄的身高)
CYZ、光哥和ZJQ等人不信教主的邪,于是他们有时候会问WD闭区间 [LR] 内有多少英雄身高大于等于C,以验证教主的魔法是否真的有效。
WD巨懒,于是他把这个回答的任务交给了你。
 

Input

       第1行为两个整数NQQ为问题数与教主的施法数总和。
       第2行有N个正整数,第i个数代表第i个英雄的身高。
       第3到第Q+2行每行有一个操作:
(1)       若第一个字母为“M”,则紧接着有三个数字LRW。表示对闭区间 [LR] 内所有英雄的身高加上W
(2)       若第一个字母为“A”,则紧接着有三个数字LRC。询问闭区间 [LR] 内有多少英雄的身高大于等于C
 

Output

       对每个“A”询问输出一行,仅含一个整数,表示闭区间 [LR] 内身高大于等于C的英雄数。
 

Sample Input

5 3
1 2 3 4 5
A 1 5 4
M 3 5 1
A 1 5 4

Sample Output

2
3

HINT

【输入输出样例说明】
原先5个英雄身高为1、2、3、4、5,此时[1, 5]间有2个英雄的身高大于等于4。教主施法后变为1、2、4、5、6,此时[1, 5]间有3个英雄的身高大于等于4。
 
【数据范围】
对30%的数据,N≤1000,Q≤1000。
对100%的数据,N≤1000000,Q≤3000,1≤W≤1000,1≤C≤1,000,000,000。

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)的更多相关文章

  1. [BZOJ3343]教主的魔法

    [BZOJ3343]教主的魔法 试题描述 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了一起,这次他们排成了一列,被编号为1.2.… ...

  2. 【BZOJ-3343】教主的魔法 分块

    3343: 教主的魔法 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 950  Solved: 414[Submit][Status][Discuss ...

  3. BZOJ3343: 教主的魔法 分块

    2016-05-28  10:27:19 题目:http://www.lydsy.com/JudgeOnline/problem.php?id=3343 比较显然的分块题,分块后块内排序,维护整块的附 ...

  4. 【bzoj3343】教主的魔法 分块

    [bzoj3343]教主的魔法 2014年4月26日8092 Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了 ...

  5. c++之路进阶——bzoj3343(教主的魔法)

    F.A.Qs Home Discuss ProblemSet Status Ranklist Contest ModifyUser  gryz2016 Logout 捐赠本站 Notice:由于本OJ ...

  6. Luogu 2801 教主的魔法 | 分块模板题

    Luogu 2801 教主的魔法 | 分块模板题 我犯的错误: 有一处l打成了1,还看不出来-- 缩小块大小De完bug后忘了把块大小改回去就提交--还以为自己一定能A了-- #include < ...

  7. 【BZOJ3343】教主的魔法 分块+二分

    Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了一起,这次他们排成了一列,被编号为1.2.…….N. 每个人的 ...

  8. 【分块】bzoj3343: 教主的魔法

    3343: 教主的魔法 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 631  Solved: 272[Submit][Status][Discuss ...

  9. BZOJ3343 & 洛谷2801:教主的魔法——题解

    http://www.lydsy.com/JudgeOnline/problem.php?id=3343 https://www.luogu.org/problemnew/show/2801 题目描述 ...

随机推荐

  1. MD5 介绍

    MD5(单向散列算法)的全称是Message-Digest Algorithm 5(信息-摘要算法),经MD2.MD3和MD4发展而来.MD5算法的使用不需要支付任何版权费用. MD5功能: 输入任意 ...

  2. Hadoop集群_VSFTP安装配置

    原作者写的太好了,我这个菜鸟不自觉就转载了,原文链接:http://www.cnblogs.com/xia520pi/archive/2012/05/16/2503864.html 如果,您认为阅读这 ...

  3. threadLocal遇上线程池导致局部变量变化

    这两天一直在查无线app一个诡异的问题,表象是stg的接口返回数据,和线上接口的返回数据不一致. 1.初步判断:有缓存,查看代码后发现缓存时间直邮6分钟,而且同一个接口,其他调用方的返回数据,stg和 ...

  4. vijos 1034 家族(水题日常)

    描述 若某个家族人员过于庞大,要判断两个是否是亲戚,确实还很不容易,现在给出某个亲戚关系图,求任意给出的两个人是否具有亲戚关系. 规定:x和y是亲戚,y和z是亲戚,那么x和z也是亲戚.如果x,y是亲戚 ...

  5. (三)mybatis之对Hibernate初了解

    前言:为什么会写Hibernate呢?因为HIbernate跟Mybatis一样,是以ORM模型为核心思想的,但是这两者有相似的地方也有差异的地方.通过这两种框架的比对,可以对mybatis有着更深的 ...

  6. 迅为IMX6Q开发板在道路交通信号控制系统解决方案中的应用

    智能交通综合管控平台是为交通指挥系统服务的统一信息平台,以信息技术为主导,以计算机通信网络和智能化指挥控制管理为基础,建成集高新技术应用为一体的智能化指挥调度集成平台,实现信息交换与共享.快速反应决策 ...

  7. (转)MyBatis框架的学习(二)——MyBatis架构与入门

    http://blog.csdn.net/yerenyuan_pku/article/details/71699515 MyBatis框架的架构 MyBatis框架的架构如下图: 下面作简要概述: S ...

  8. spark 的RDD各种转换和动作

    今天先把spark的各种基本转换和动作总结下,以后有时间把各种用法放上去. 1 RDD基本转换操作    map.flagMap.distinct coalesce.repartition coale ...

  9. python打开.pkl的文件并显示里面的内容

    pkl文件是pyhthon里面保存文件的一种格式,如果直接打开会显示一堆序列化的东西.正确的打开方式如下: import cPickle as pickle f = open('path') info ...

  10. Spring启动流程—源码解读

    https://blog.csdn.net/yangliuhbhd/article/details/80790761 Spring的AbstractApplicationContext的refresh ...