刷题总结——教主的魔法(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 题目描述 ...
随机推荐
- COGS 615. 韩国明星
[问题描述] 在LazyCat同学的影响下,Roby同学开始听韩国的音乐,并且越来越喜欢H.o.T,尤其喜欢安七炫和Tony,可是,爱学习爱思考的Roby同学想,如果以后喜欢的韩星越来越多怎么办呢?R ...
- codevs 3278 最小m 段和问题
时间限制: 1 s 空间限制: 256000 KB 题目等级 : 黄金 Gold 题目描述 Description 给定 n 个整数(不一定是正整数)组成的序列,现在要求将序列分割为 m 段,每段 ...
- 什么是闭包(Closure)?
http://kb.cnblogs.com/page/111780/ 这个问题是在最近一次英格兰Brighton ALT.NET Beers活动中提出来的.我发现,如果不用代码来演示,你很难单用话语把 ...
- mac 上使用移动硬盘
1. 打开终端,查看赢盘的Volume Name diskutil list 2. 更新fstab文件,此步骤需要输入密码 sudo nano /etc/fstab 3. 在fstab文件中写入一下内 ...
- 阿里Java架构师面试高频300题:集合+JVM+Redis+并发+算法+框架等
前言 在过2个月即将进入9月了,然而面对今年的大环境而言,跳槽成功的难度比往年高了很多,很明显的感受就是:对于今年的java开发朋友跳槽面试,无论一面还是二面,都开始考验一个Java程序员的技术功底和 ...
- vue 动态合并单元格、并添加小计合计功能
1.效果图 2.后台返回数据格式(平铺式) 3.后台返回数据后,整理所需要展示的属性存储到(items)数组内 var obj = { "id": curItems[i].id, ...
- fckeditor配置详解
使用配置设置: . FCKConfig.CustomConfigurationsPath = '' ; // 自定义配置文件路径和名称 . FCKConfigFCKConfig.EditorAreaC ...
- C++_STL基础案例
C++ C++三种容器:list.vector和deque的区别:https://blog.csdn.net/gogokongyin/article/details/51178378 一.容器 小常识 ...
- POJ-3050-Hoscotch
这是一道简单的深搜题目,题意说的是给一个5*5的棋盘,里面填满数字,然后跳到一个格子上,这是第一步,接着向上下左右四个方向任意一个方向走一步,一共走6步,问我们走过的数字组成的一个6位数有多少种不同的 ...
- 身为前端开发工程师,你需要了解的搜索引擎优化SEO.
网站url网站创建具有良好描述性.规范.简单的url,有利于用户更方便的记忆和判断网页的内容,也有利于搜索引擎更有效的抓取您的网站.网站设计之初,就应该有合理的url规划. 处理方式: 1.在系统中只 ...