因为询问比较少,所以我们可以将n个数分成sqrt(n)个块,每个块用一颗bst存一下,然后对于修改l,r,我们将l,r区间中整块的直接在bst上打一个标签,对于不是整块的我们直接暴力修改,对于询问l,r,仍然是整块的直接在bst中求大于c的个数(考虑标签),然后不是整块的部分暴力扫一遍更新答案。

  我写的sbt,可能是sbt常数比较大什么的,tle了,其实对于每一个块我们可以快排保存,然后询问的时候二分就好了。然后对于不是整块的修改和询问可以直接改完之后再快排,这样常数小了很多。

  懒得改了,贴sbt的吧。

/**************************************************************
Problem: 3343
User: BLADEVIL
Language: C++
Result: Accepted
Time:9976 ms
Memory:47712 kb
****************************************************************/ #include <cstdio>
#include <algorithm>
#include <cstring>
#include <cmath>
using namespace std ;
#define MAXN 2000100
#define MAXB 1100
#define L( t ) Left[ t ]
#define R( t ) Right[ t ]
#define K( t ) Key[ t ]
#define S( t ) Size[ t ]
#define update( t )S( t )=S(L( t ))+S(R( t ))+1
#define check( ch )( ch >='0'&& ch <='9')
void getint(int&t ){
int ch ;for( ch =getchar( );!check( ch ); ch =getchar( ));
t = ch -'';
for( ch =getchar( );check( ch ); ch =getchar( )) t *=, t += ch -'';
}
int Left[ MAXN ], Right[ MAXN ], Key[ MAXN ], Size[ MAXN ], V =;
void left(int&t ){
int k =R( t );
R( t )=L( k );update( t );
L( k )= t ;update( k );
t = k ;
}
void right(int&t ){
int k =L( t );
L( t )=R( k );update( t );
R( k )= t ;update( k );
t = k ;
}
void maintain(int&t ){
if(S(L(L( t )))>S(R( t ))){
right( t );
maintain(R( t ));maintain( t );
return;
}
if(S(R(R( t )))>S(L( t ))){
left( t );
maintain(L( t ));maintain( t );
return;
}
if(S(R(L( t )))>S(R( t ))){
left(L( t ));right( t );
maintain(L( t )),maintain(R( t ));
maintain( t );
return;
}
if(S(L(R( t )))>S(L( t ))){
right(R( t ));left( t );
maintain(L( t )),maintain(R( t ));
maintain( t );
return;
}
}
void Insert(int k ,int&t ){
if(! t ){
t =++ V ;
L( t )=R( t )=;
S( t )=,K( t )= k ;
return;
}
S( t )++;
Insert( k , k <K( t )?L( t ):R( t ));
maintain( t );
} void Delete(int k ,int&t ){
if( k ==K( t )){
if(!L( t )){
t =R( t );return;
}
if(!R( t )){
t =L( t );return;
}
right( t );Delete( k ,R( t ));
}else Delete( k , k <K( t )?L( t ):R( t ));
update( t );
maintain( t );
} int Rank(int k ,int t ){
if(! t )return ;
if( k <=K( t ))return S(R( t ))++Rank( k ,L( t ));
return Rank( k ,R( t ));
}
int a[ MAXN ], block[ MAXN ], head[ MAXB ], tail[ MAXB ], roof[ MAXB ], C[ MAXB ];
int n , m , b =;
int Query(int l ,int r ,int c ){
if( block[ l ]== block[ r ]){
int x = block[ l ];
if( head[ x ]== l && tail[ x ]== r )return Rank( c - C[ x ], roof[ x ]);
int cnt =;
for(int i = l ; i <= r ; i ++)if( a[ i ]>= c - C[ x ]) cnt ++;
return cnt ;
}
int cnt =Query( l , tail[ block[ l ]], c )+Query( head[ block[ r ]], r , c );
for(int i = block[ l ]+; i < block[ r ]; i ++){
cnt +=Rank( c - C[ i ], roof[ i ]);
}
return cnt ;
} void Change(int l ,int r ,int c ){
if( block[ l ]== block[ r ]){
int x = block[ l ];
if( l == head[ x ]&& r == tail[ x ]){
C[ x ]+= c ;
return;
}
for(int i = l ; i <= r ; i ++){
Delete( a[ i ], roof[ x ]);
a[ i ]+= c ;
Insert( a[ i ], roof[ x ]);
}
return;
}
Change( l , tail[ block[ l ]], c ),Change( head[ block[ r ]], r , c );
for(int i = block[ l ]+; i < block[ r ]; i ++){
C[ i ]+= c ;
}
} int main( ){
memset( roof ,,sizeof( roof ));
memset( C ,,sizeof( C ));
L()=R()=S()=;
getint( n ),getint( m );
for(int i =; i ++< n ;)getint( a[ i ]);
b =int(sqrt( n ));
for(int i =; i ++< b ;){
for(int j =( i -)* b ; j ++< i * b ;){
block[ j ]= i ;
Insert( a[ j ], roof[ i ]);
}
head[ i ]=( i -)* b +, tail[ i ]= i * b ;
}
if( b * b < n ){
head[ b +]= b * b +, tail[ b +]= n ;
for(int i = b * b ; i ++< n ;){
block[ i ]= b +;
Insert( a[ i ], roof[ b +]);
}
}
while( m --){
int ch , l , r , c ;
for( ch =getchar( );!( ch >='A'&& ch <='Z'); ch =getchar( ));
if( ch =='M'){
getint( l ),getint( r ),getint( c );
Change( l , r , c );
}else{
getint( l ),getint( r ),getint( c );
printf("%d\n",Query( l , r , c ));
}
}
return ;
}

bzoj 3343 分块的更多相关文章

  1. BZOJ 3343: 教主的魔法(分块+二分查找)

    BZOJ 3343: 教主的魔法(分块+二分查找) 3343: 教主的魔法 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1172  Solved:  ...

  2. BZOJ 3343: 教主的魔法 [分块]【学习笔记】

    3343: 教主的魔法 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1172  Solved: 526[Submit][Status][Discus ...

  3. 【BZOJ 3343 】 分块

    3343: 教主的魔法 Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了一起,这次他们排成了一列,被编号为1. ...

  4. 分块+二分 BZOJ 3343

    3343: 教主的魔法 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1312  Solved: 585[Submit][Status][Discus ...

  5. BZOJ 3343:教主的魔法(分块)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3343 [题目大意] 给出一个数列,有区间加法操作,询问区间大于等于c的数字个数 [题解 ...

  6. Bzoj 3343: 教主的魔法(分块+二分答案)

    3343: 教主的魔法 Time Limit: 10 Sec Memory Limit: 256 MB Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息 ...

  7. Bzoj 3343: 教主的魔法 分块,二分

    3343: 教主的魔法 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 821  Solved: 364[Submit][Status][Discuss ...

  8. BZOJ 3343 教主的魔法(分块)

    题意: 有一个1e6的数组,t次操作:将[l,r]内的值增加w,或者查询[l,r]内的值大于等于add的 思路: 分块,块大小为sqrt(n),每次只需要暴力头尾两块,中间的整块打标记, 对于查询查操 ...

  9. bzoj 3343 教主的魔法 分块

    修改直接对整块打标记,两边暴力. 查询需要保证每个整块有序,所以在修改时排序就好啦 #include<cstdio> #include<cstring> #include< ...

随机推荐

  1. s3c2440调试nandflash裸机程序遇到的问题

    图挂了可以去 https://github.com/tanghammer/mini2440_peripherals/blob/master/nand/debug_nand.md 按照前面sdram的代 ...

  2. PAT L1-039 古风排版

    https://pintia.cn/problem-sets/994805046380707840/problems/994805091888906240 中国的古人写文字,是从右向左竖向排版的.本题 ...

  3. 重新看《JavaScript高级程序设计》

    几点心得: 1)数据是基础,一共有3种基础数据:null.undefined.和object:遵循从无到有从简单到复杂的演变过程 2)衍生数据:衍生数据是指操作符合语句,这些是基础数据产生导致的必然结 ...

  4. 内存交换空间(swap)的构建

    一.使用物理分区构建swap 1.先进行分区的行为. [root@iZ255cppmtxZ ~]# fdisk /dev/xvdb Welcome to fdisk (util-linux ). Ch ...

  5. RT-thread-2.0.1移植(基于STM32F4xx)

    1.将下载的rt-thread-2.0.1解压后,得到如下图所示的文件列表. 在bsp目录下可以找到stm32f40x文件夹,这文件夹里面包括了库函数,其他芯片平台的文件夹统统删掉.在libcpu下, ...

  6. Luogu3147 USACO16OPEN 262144(动态规划)

    感觉上这个题是可以直接暴力的,每次根据一段连续最小值个数的奇偶性决定是否划分区间,递归处理.然而写起来实在太麻烦了. 设f[i][j]为以i为左端点合并出j时的右端点.则有f[i][j]=f[f[i] ...

  7. poj2018——Best Cow Fences

    Description Farmer John's farm consists of a long row of N (1 <= N <= 100,000)fields. Each fie ...

  8. 【BZOJ4889】[Tjoi2017]不勤劳的图书管理员 分块+树状数组

    [BZOJ4889][Tjoi2017]不勤劳的图书管理员 题目描述 加里敦大学有个帝国图书馆,小豆是图书馆阅览室的一个书籍管理员.他的任务是把书排成有序的,所以无序的书让他产生厌烦,两本乱序的书会让 ...

  9. [zhuan]Android 异常处理:java.lang.IllegalArgumentException(...contains a path separator)

    http://blog.csdn.net/alex_zhuang/article/details/7340901 对以下错误: Java.lang.RuntimeException: java.lan ...

  10. crontab使用进程锁解决冲突

    想到一个问题,如果在crontab里有个定时任务设置为一分钟执行一次,但是它执行的时间可能会超过一分钟,此时crontab一分钟后会再次运行该脚本吗?这样会不会出现冲突呢?网上找了下,说可以用Linu ...