题目:

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. 最小化安装centos后ifconfig看不到eth0

    最小换安装centos后,ifconfig看不到eth0,只看到一个lo ifup eth0

  2. JS判断两个对象相同属性的属性值是否相等

    function isObjectValueEqual(a, b) { var aProps = Object.getOwnPropertyNames(a); var bProps = Object. ...

  3. # iOS Block的本质(三)

    iOS Block的本质(三) 上一篇文章iOS Block的本质(二)中已经介绍过block变量的捕获,本文继续探寻block的本质. 1. block对对象变量的捕获,ARC 环境 block一般 ...

  4. LR中下载文件的脚本

    #include "web_api.h" Action(){ int iflen; //文件大小 long lfbody; //响应数据内容大小 web_url("xxx ...

  5. SQL 基本编程

    定义变量 赋值 取值 分支语句 循环语句 定义变量 declare @变量   数据类型          //@必须带着  不然程序不知道变量是什么  不带@   电脑会报错 例如 declare ...

  6. Android学习总结(七)———— 本地广播

    一.本地广播 2.1 基本概念 由于之前的广播都是全局的,所有应用程序都可以接收到,这样就很容易会引起安全性的问题,比如说我们发送一些携带关键性数据的广播有可能被其他的应用程序截获,或者其他的程序不停 ...

  7. POJ 2152 Fire (树形DP,经典)

    题意:给定一棵n个节点的树,要在某些点上建设消防站,使得所有点都能够通过某个消防站解决消防问题,但是每个点的建站费用不同,能够保证该点安全的消防站的距离上限也不同.给定每个点的建站费用以及最远的消防站 ...

  8. 【原创】最有效解决IE8 position兼容性问题

    看了网上的的帖子真是水的一塌糊涂,完全没有解决我和广大网友们的关于ie8下position兼容性问题. 网上有的技术我就不说了 ,大家自行搜索,我想说的重点是 ie8不支持html5的新标签.这是重点 ...

  9. RLock(递归锁)

    import threading, time def run1(): print("grab the first part data") lock.acquire()#进入大门后的 ...

  10. shell脚本,awk如何处理文件中上下关联的两行。

    文件d.txt如下内容 ggg 1portals: 192.168.5.41:3260werew 2portals: 192.168.5.43:3260 如何把文件d.txt内容变为如下内容 ggg  ...