bzoj 3343: 教主的魔法
Time Limit: 10 Sec Memory Limit: 256 MB
Submit: 924 Solved: 402
[Submit][Status][Discuss]
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
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<queue>
#include<vector>
using namespace std;
typedef long long LL;
const int maxn=;
int N,Q,M,block;
int a[maxn],b[maxn],pos[maxn],add[maxn];
char s[];
inline void reset(int x){
int l=(x-)*block+,r=min(N,x*block);
for(int i=l;i<=r;i++) b[i]=a[i];
sort(b+l,b+r+);
}
inline void update(int l,int r,int delta){
if(pos[l]==pos[r]){
for(int i=l;i<=r;i++) a[i]+=delta;
}
else{
for(int i=l;i<=pos[l]*block;i++) a[i]+=delta;
for(int i=(pos[r]-)*block+;i<=r;i++) a[i]+=delta;
}
reset(pos[l]); reset(pos[r]);
for(int i=pos[l]+;i<=pos[r]-;i++) add[i]+=delta;
}
inline int find(int l,int r,int v){
if(l+>=r){
if(b[l]>=v) return l;
else return r;
}
int mid=(l+r)>>;
if(b[mid]>=v) return find(l,mid,v);
else return find(mid+,r,v);
}
inline int query(int l,int r,int z){
int sum=;
if(pos[l]==pos[r]){
for(int i=l;i<=r;i++)
if(a[i]+add[pos[i]]>=z) sum++;
}
else{
for(int i=l;i<=pos[l]*block;i++)
if(a[i]+add[pos[i]]>=z) sum++;
for(int i=(pos[r]-)*block+;i<=r;i++)
if(a[i]+add[pos[i]]>=z) sum++;
}
for(int i=pos[l]+;i<=pos[r]-;i++){
sum+=(i*block+)-find((i-)*block+,i*block+,z-add[i]);
}
return sum;
}
int main(){
scanf("%d%d",&N,&Q);
block=int(sqrt(N));
for(int i=;i<=N;i++){
scanf("%d",&a[i]); b[i]=a[i];
pos[i]=(i-)/block+;
}
if(N%block!=) M=N/block+;
else M=N/block;
for(int i=;i<=M;i++) reset(i);
while(Q--){
int x,y,z;
scanf("%s%d%d%d",s,&x,&y,&z);
if(s[]=='M') update(x,y,z);
else printf("%d\n",query(x,y,z));
}
return ;
}
bzoj 3343: 教主的魔法的更多相关文章
- BZOJ 3343: 教主的魔法(分块+二分查找)
BZOJ 3343: 教主的魔法(分块+二分查找) 3343: 教主的魔法 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1172 Solved: ...
- BZOJ 3343: 教主的魔法 [分块]【学习笔记】
3343: 教主的魔法 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1172 Solved: 526[Submit][Status][Discus ...
- Bzoj 3343: 教主的魔法 分块,二分
3343: 教主的魔法 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 821 Solved: 364[Submit][Status][Discuss ...
- Bzoj 3343: 教主的魔法(分块+二分答案)
3343: 教主的魔法 Time Limit: 10 Sec Memory Limit: 256 MB Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息 ...
- BZOJ——3343: 教主的魔法 || 洛谷—— P2801 教主的魔法
http://www.lydsy.com/JudgeOnline/problem.php?id=3343 || https://www.luogu.org/problem/show?pid=280 ...
- BZOJ 3343教主的魔法
Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了一起,这次他们排成了一列,被编号为1.2.…….N. 每个人的 ...
- bzoj 3343 教主的魔法 分块
修改直接对整块打标记,两边暴力. 查询需要保证每个整块有序,所以在修改时排序就好啦 #include<cstdio> #include<cstring> #include< ...
- [bzoj] 3343 教主的魔法 || 带修改分块
原题 长度为n的序列,有两种操作: 1.[l,r]区间每个数+w 2.询问[l,r]区间有多少个数>c 记录lazy数组即可. #include<cstdio> #include&l ...
- 块状链表 bzoj 3343教主的魔法
//块状链表//分块排序,然后每次查找时在暴力查找头和尾两个块.//中间那些块,因为有序所以只需2分查找即可.我用的是lower_pound();//插入是,也是头和尾暴力插入,中间那些加到一个累计里 ...
随机推荐
- nodejs(五)同步异步--USING SETTIMEOUT INSTEAD OF SETINTERVAL TO FORCE SERIALIZATION
Let’s say you want a function that does some I/O — such as parsing a log fi le — that will periodica ...
- ie8兼容半透明效果css
1.opacity:0.5;(半透明效果在ie9及以上版本适用,ie8及以下不兼容) 解决办法:在css中加入filter: progid:DXImageTransform.Microsoft.Alp ...
- 分布式网格缓存Coherence简介
Coherence企业级缓存(一) 特点 摘要:Oracle Coherence是一个企业级的分布式集群缓存框架.具有自管理,自恢复,高可用性,高扩展性等优良特点,在电信BOSS等项目中有很大的应用价 ...
- Lodash入门介绍
原文额地址 http://www.w3cplus.com/javascript/lodash-intro.html 有多年开发经验的工程师,往往都会有自己的一套工具库,称为 utils.helper ...
- 既生list何生tuple
python中list是可以修改的;若要创建一系列不可修改的元素时,就需要tuple. 用 tuple 的好处: 1.tuple 比 list 操作速度快.如果您定义了一个值的常量集,并且唯一要用它做 ...
- PAT 1016 Phone Bills[转载]
1016 Phone Bills (25)(25 分)提问 A long-distance telephone company charges its customers by the followi ...
- Approximate Inference
1. Approximation Probabilistic model 中的一个 central task :给定一组observation X 后,计算latent variables ...
- [lr] 基本色调调整和色调曲线
基本色调调整 • 曝光度调整 ▶ 控制区域 在Lightroom中,软件提示我们曝光控制的是如图中间调的区域.我们把鼠标移动到曝光工具条上,软件会提示我们这个区域: ▶ 实际效果 ▪ 增加曝光值 增加 ...
- 使用Fiddler手机抓包https-----重要
Fiddler不仅可以对手机进行抓包,还可以抓取别的电脑的请求包,今天就想讲一讲使用Fiddler手机抓包! 使用Fiddler手机抓包有两个条件: 一:手机连的网络或WiFi必须和电脑(使用fidd ...
- Linux系统——Nginx反向代理与负载均衡
集群集群是指一组(若干个)相互独立的计算机,利用高速通信网路组成的一个较大的计算机服务系统,每个集群节点(即集群中的每台计算机)都是运用各自服务的独立服务器.这些服务器之间可以彼此通信,协同向用户提供 ...