块状链表 bzoj 3343教主的魔法
//块状链表
//分块排序,然后每次查找时在暴力查找头和尾两个块。
//中间那些块,因为有序所以只需2分查找即可。我用的是lower_pound();
//插入是,也是头和尾暴力插入,中间那些加到一个累计里即可。
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<iostream>
using namespace std;
int a[1000005],b[1000005],lei[1000005],dian[1000005],l[1000005],r[1000005];
int n,m,len,len1;
char ch[2];
void jian(int a1)
{
l[a1]=(a1-1)*len1+1;
r[a1]=min(a1*len1,n);
for(int i=l[a1];i<=r[a1];i++)
b[i]=a[i];
sort(b+l[a1],b+r[a1]+1);
}
void jia(int a1,int a2,int a3)
{
if(dian[a1]==dian[a2])
{
for(int i=a1;i<=a2;i++)
a[i]+=a3;
jian(dian[a1]);
return;
}
for(int i=a1;i<=r[dian[a1]];i++)
a[i]+=a3;
for(int i=l[dian[a2]];i<=a2;i++)
a[i]+=a3;
for(int i=dian[a1]+1;i<dian[a2];i++)
lei[i]+=a3;
jian(dian[a1]);
jian(dian[a2]);
return;
}
int zhao(int a1,int a2,int a3)
{
int sum=0,s;
if(dian[a1]==dian[a2])
{
for(int i=a1;i<=a2;i++)
if(a[i]+lei[dian[a1]]>=a3)
sum++;
return sum;
}
for(int i=a1;i<=r[dian[a1]];i++)
if(a[i]+lei[dian[a1]]>=a3)
sum++;
for(int i=l[dian[a2]];i<=a2;i++)
if(a[i]+lei[dian[a2]]>=a3)
sum++;
for(int i=dian[a1]+1;i<dian[a2];i++)
{
s=lower_bound(b+l[i],b+r[i]+1,a3-lei[i])-b;
sum+=r[i]+1-s;
}
return sum;
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
scanf("%d",&a[i]);
len1=floor(sqrt(n));
len=n/len1;
if(n%len1)
len++;
for(int i=1;i<=len;i++)
jian(i);
for(int i=1;i<=n;i++)
dian[i]=(i-1)/len1+1;
for(int i=0;i<m;i++)
{
int a1,a2,a3;
scanf("%s%d%d%d",ch,&a1,&a2,&a3);
if(ch[0]=='A')
printf("%d\n",zhao(a1,a2,a3));
else
jia(a1,a2,a3);
}
return 0;
}
块状链表 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: 教主的魔法
Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 924 Solved: 402[Submit][Status][Discuss] Descriptio ...
- bzoj 3343 教主的魔法 分块
修改直接对整块打标记,两边暴力. 查询需要保证每个整块有序,所以在修改时排序就好啦 #include<cstdio> #include<cstring> #include< ...
- [bzoj] 3343 教主的魔法 || 带修改分块
原题 长度为n的序列,有两种操作: 1.[l,r]区间每个数+w 2.询问[l,r]区间有多少个数>c 记录lazy数组即可. #include<cstdio> #include&l ...
随机推荐
- 基本数据类型和string的转换
- hadoop 完全分布式搭建总结
完全分布式--------------- 1.配置文件 [core-site.xml] hdfs 地址 fs.defaultFS=hdfs://s129:8020/ [hdfs-site.xml] 副 ...
- 异常:[vue/no-parsing-error] Parsing error:x-invalid-end-tag
- typescript 入门教程四
ts中的function和接口 interface PrintCallback{ // 匿名函數,返回类型为空 (success:boolean):void } interface Person{ / ...
- windows + Eclipse
https://www.eclipse.org/downloads/index-packages.php 下载好后是一个压缩文件,解压并放到相要存放软件的目录,双击打开解压后的目录下eclipse.e ...
- Java 之 File类(文件操作)
一.概述 java.io.File 类是文件和目录路径名册抽象表示,主要用于文件和目录的创建.查找和删除等操作. File类是一个与系统无关的类,任何的操作系统都可以使用这个类中的方法. 路径问题: ...
- cdc跨时钟域处理-结绳握手法
参考文档 https://blog.csdn.net/u011412586/article/details/10009761 前言 对于信号需要跨时钟域处理而言,最重要的就是确保数据能稳定的传送到采样 ...
- MM-自制件改外购件
自制件改外购件 https://wenku.baidu.com/view/fbb182c6bb4cf7ec4afed081.html
- null和空的区别
python中None和Null的区别 首先了解python对象的概念 python中,万物皆对象,所有的操作都是针对对象的. 那什么是对象?5是一个int对象,‘oblong’是一个str对象,异常 ...
- Django+bootstrap+注册登录系统
转自:https://www.cnblogs.com/robindong/p/9610057.html Robin_D 博客园 首页 新随笔 联系 订阅 管理 随笔 - 10 文章 - 0 评论 ...