Bzoj 3343: 教主的魔法 分块,二分
3343: 教主的魔法
Time Limit: 10 Sec Memory Limit: 256 MB
Submit: 821 Solved: 364
[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
Source
#include<bits/stdc++.h>
using namespace std;
#define MAXN 1000010
int N,a[MAXN],h[MAXN],pos[MAXN],add[],block;
int read()
{
int s=,fh=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')fh=-;ch=getchar();}
while(ch>=''&&ch<=''){s=s*+(ch-'');ch=getchar();}
return s*fh;
}
void cl(int k)
{
int l=(k-)*block+,r=min(k*block,N),i;
for(i=l;i<=r;i++)a[i]=h[i];
sort(a+l,a+r+);
}
void Add(int l,int r,int c)
{
int i;
if(pos[l]==pos[r])
{
for(i=l;i<=r;i++)h[i]+=c;
cl(pos[l]);
}
else
{
for(i=l;i<=pos[l]*block;i++)h[i]+=c;
for(i=(pos[r]-)*block+;i<=r;i++)h[i]+=c;
for(i=pos[l]+;i<=pos[r]-;i++)add[i]+=c;
cl(pos[l]);cl(pos[r]);
}
}
int Find(int k,int c)
{
int l=(k-)*block+,r=min(k*block,N),t=,mid;
while(l<=r)
{
mid=(l+r)/;
if(a[mid]<c)l=mid+;
else t=mid,r=mid-;
}
if(t==)return ;
return min(k*block,N)-t+;
}
int Query(int l,int r,int c)
{
int ans=,i;
if(pos[l]==pos[r])
{
for(i=l;i<=r;i++)if(h[i]+add[pos[i]]>=c)ans++;
}
else
{
for(i=l;i<=pos[l]*block;i++)if(h[i]+add[pos[i]]>=c)ans++;
for(i=(pos[r]-)*block+;i<=r;i++)if(h[i]+add[pos[i]]>=c)ans++;
for(i=pos[l]+;i<=pos[r]-;i++)ans+=Find(i,c-add[i]);
}
return ans;
}
int main()
{
int Q,i,m,L,R,W;
char fh[];
N=read();Q=read();
block=(int)sqrt(N);
for(i=;i<=N;i++)
{
h[i]=read();
pos[i]=(i-)/block+;
}
if(N==block*block)m=block;
else m=block+;
for(i=;i<=m;i++)cl(i);
for(i=;i<=Q;i++)
{
scanf("\n%s",fh);L=read();R=read();W=read();
if(fh[]=='M')Add(L,R,W);
else printf("%d\n",Query(L,R,W));
}
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 MB Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息 ...
- BZOJ 3343: 教主的魔法 [分块]【学习笔记】
3343: 教主的魔法 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1172 Solved: 526[Submit][Status][Discus ...
- bzoj 3343 教主的魔法 分块
修改直接对整块打标记,两边暴力. 查询需要保证每个整块有序,所以在修改时排序就好啦 #include<cstdio> #include<cstring> #include< ...
- 【BZOJ3343】教主的魔法 分块+二分
Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了一起,这次他们排成了一列,被编号为1.2.…….N. 每个人的 ...
- bzoj 3343: 教主的魔法
Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 924 Solved: 402[Submit][Status][Discuss] Descriptio ...
- 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 教主的魔法(分块)
题意: 有一个1e6的数组,t次操作:将[l,r]内的值增加w,或者查询[l,r]内的值大于等于add的 思路: 分块,块大小为sqrt(n),每次只需要暴力头尾两块,中间的整块打标记, 对于查询查操 ...
随机推荐
- mysql远程连接缓慢的问题
这两天发现服务器程序启动的时候到了mysql初始连接的那一步很耗时,启动缓慢,后来发现,将连接的主机的-h参数改成localhost的时候 瞬间就完成连接了.后来在网上查到,原来是由于mysql服务器 ...
- java中移位运算符:<<、>>和>>>之间的比较
一.说明 <<:运算符将二进制位进行左移操作 >>:运算符将二进制位进行右移操作 >>>:运算符将用0填空高位 二.举例 /** * *----------c ...
- 【Android】 Sqlite3 not found
调试机没有sqlite3命令文件 导入即可 sqlite3 http://pan.baidu.com/s/1bohTMiz //(使用老版sqlite3需要导入libncurses.so文件至/sys ...
- std::string stringf(const char* format, ...)
std::string stringf(const char* format, ...){ va_list arg_list; va_start(arg_list, format); // SUSv2 ...
- TDirectory.Copy复制文件
描述:复制文件夹以及文件夹下的内容 procedure Copy(const SourceDirName, DestDirName: string) 参数一:源文件夹 参数二:目标文件夹 所在单元:S ...
- magento install
1: apt-get insatll apache2 mysql php5 2: 把下载的magneto 解压后放到 /var/www/magento 3: 进入 http://127. ...
- Soy文件生成JS文件 - 一个使用Google soy模板的例子
1.下载工具包,后解压. http://closure-templates.googlecode.com/files/closure-templates-for-javascript-latest.z ...
- Navigation学习笔记
***************************** 使用storyboard导航********************************* storyboard方式相对简单. 在弹出来 ...
- LED汽车前大灯
一.LED汽车前大灯遇到问题.分析和解决 问题1: 当电源电压增大时,LED等闪烁,而且电源电压增大的越多闪烁的频率越低. 原因分析: 电源电压从12V升高到24V过程中,开关MOS管的Vds增大,Q ...
- 在mac系统安装Apache Tomcat的详细步骤
对于Apache Tomcat 估计很多童鞋都会,那么今天就简单说下在mac上进行tomcat的安装: 第一步:下载Tomcat 这里Himi下载的tomcat version:7. ...