luo3372线段树模板的分块做法
题目大意
请你维护一个有n个元素的整数序列,要求支持区间查询&区间修改
对于100%的数据,\(1<=n<=10^5\)
分析
正常做法是线段树维护区间修改、区间查询,今天我要讲的是一种暴力做法:分块
分块的思想并不复杂,分块把一个长度为n的区间分成num段,操作时如果是整段用标记修改,不是整段的部分暴力修改
分析时间复杂度:在这题中,每段的标记修改是\(O(1)\)的,最多有num段,整段标记修改所用时间是\(O(num)\)的;不是整段的部分最多有\(O(n/num)\)个,暴力修改所用的时间是\(O(n/num)\)的;所以总时间是\(O(num+n/num)\)。
根据基本不等式,num取\(\sqrt n\)时该式有最小值;所以num取\(\sqrt n\)。
实现
分块的思想并不复杂,时间复杂度也不玄学,但是实现起来并不方便(可能是我弱)
分块的修改/查询都分为2部分:
- 整块的修改
- “零头”的修改
整块的修改是否简便:add[i] += val;
“零头”的修改直接修改,同时不要忘了维护所在块的信息:
a[i] += val;
sum[id[i]] += val;
修改就愉快地解决了,查询和修改差不多。
完整代码
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
const int maxn = 100007;
int n, m, num, id[maxn];
long long sum[1000], add[1000], a[maxn];
int main(){
scanf("%d%d", &n, &m);
num = sqrt(n);
for (int i = 1; i <= n; ++i){
scanf("%lld", &a[i]);
id[i] = (i-1) / num;
sum[id[i]] += a[i];
}
while (m--){
int d; scanf("%d", &d);
if (d==1){
int x, y, C; scanf("%d%d%d", &x, &y, &C);
int Leftid = (x-1) / num + 1;
int Rightid = (y-1) / num - 1;
long long res = 0;
for (int i = Leftid; i <= Rightid; ++i)
add[i] += C;
for (int i = x; i <= Leftid * num; ++i)
a[i] += C, sum[id[i]] += C;
for (int i = (Rightid+1)*num+1; i <= y; ++i)
a[i] += C, sum[id[i]] += C;
}else{
int x, y; scanf("%d%d", &x, &y);
int Leftid = (x-1) / num + 1;
int Rightid = (y-1) / num - 1;
if (id[x] == id[y]){
long long res = 0;
for (int i = x; i <= y; ++i)
res += a[i] + add[id[i]];
printf("%lld\n", res);
continue;
}
long long res = 0;
for (int i = Leftid; i <= Rightid; ++i)
res += sum[i] + add[i] * num;
for (int i = x; i <= Leftid * num; ++i)
res += a[i] + add[Leftid-1];
for (int i = (Rightid+1)*num+1; i <= y; ++i)
res += a[i] + add[Rightid+1];
printf("%lld\n", res);
}
}
return 0;
}
luo3372线段树模板的分块做法的更多相关文章
- 洛谷P4344 脑洞治疗仪 [SHOI2015] 线段树+二分答案/分块
!!!一道巨恶心的数据结构题,做完当场爆炸:) 首先,如果你用位运算的时候不小心<<打成>>了,你就可以像我一样陷入疯狂的死循环改半个小时 然后,如果你改出来之后忘记把陷入死循 ...
- [AHOI 2009] 维护序列(线段树模板题)
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MB Description 老师交给小可可一个维护数列的任务,现在小 ...
- hdu1754 I hate it线段树模板 区间最值查询
题目链接:这道题是线段树,树状数组最基础的问题 两种分类方式:按照更新对象和查询对象 单点更新,区间查询; 区间更新,单点查询; 按照整体维护的对象: 维护前缀和; 维护区间最值. 线段树模板代码 # ...
- P3373 线段树模板
好,这是一个线段树模板. #include <cstdio> using namespace std; ; long long int sum[N],tag1[N],tag2[N],mo; ...
- 线段树模板hdu 1754:I Hate It
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- UESTC - 1057 秋实大哥与花 线段树模板题
http://acm.uestc.edu.cn/#/problem/show/1057 题意:给你n个数,q次操作,每次在l,r上加上x并输出此区间的sum 题解:线段树模板, #define _CR ...
- POJ 3468 A Simple Problem with Integers(线段树模板之区间增减更新 区间求和查询)
A Simple Problem with Integers Time Limit: 5000MS Memory Limit: 131072K Total Submissions: 140120 ...
- hdu 4819 二维线段树模板
/* HDU 4819 Mosaic 题意:查询某个矩形内的最大最小值, 修改矩形内某点的值为该矩形(Mi+MA)/2; 二维线段树模板: 区间最值,单点更新. */ #include<bits ...
- POJ3468:A Simple Problem with Integers(线段树模板)
A Simple Problem with Integers Time Limit: 5000MS Memory Limit: 131072K Total Submissions: 149972 ...
随机推荐
- 分布式监控系统开发【day37】:表结构设计(二)
一.表结构关系图 二.表结构需求讨论 1.主机表(Host) 1.解决了什么问题? 1.如果我不想让它监控了,就有一个开关的东西给它禁掉2.主机存活状态检测间隔 2.代码 class Host(mod ...
- Fiddler--Composer
Composer选项卡支持手动构建和发请求:也可以在Session列表中拖拽Session放到Composer中,把该Session的请求复制到用户界面: 点击"execute"按 ...
- 用Java编写第一个区块链
原文地址:https://www.cnblogs.com/zacky31/p/9057193.html 目标: 创建一个最基本的“区块链” 实现一个简单的挖矿系统 前提: 对面向对象编程有一定的基础 ...
- mysql数据库truncate表时间长处理
[环境介绍] 系统环境:Linux + mysql 5.7.18 + 主从复制架构 [背景描述] 客户反映用在mysql数据库上truncate一个innode引擎的list分区100G左右表时,耗时 ...
- split host
# encoding:utf-8 _portprog = None def split_host_port(host): """ split the host :para ...
- 使用PHP中的ajax做登录页面、验证用户名是否可用、动态调用数据库
1.ajax的基础知识 ajax是结合了jquery.php等几种技术延伸出来的综合运用的技术,不是新的内容.ajax也是写在<script>标签里面的. 如果使用ajax一定是要有1个处 ...
- AB PLC与西门子S7-1200以太网通信
前言:在项目实际应用中,经常会遇到两个不同厂家的PLC需要互联进行通信交换数据,由于各自的通信协议有所不同,实现起来的难度较大,通常的做法是借助第三方的网关.本文介绍的是AB PLC与西门子S7-12 ...
- 使用Notepad++开发Java程序
安装NppExec插件(已安装可跳过) 插件下载地址 我选择了最新的RC2 根据软件位数下载对应的版本,我直接下载了32位对应的dll 解压后里面有两个文件夹和一个dll文件 拷贝到Notepad++ ...
- mysql-8.0.11安装步骤
1.下载好安装包:mysql-8.0.11-winx64.zip 2.解压到合适的目录,例如:C:\XQ\Soft\mysql-8.0.11-winx64 3.在目录下创建my.ini文件,配置bas ...
- 20175204 张湲祯 2018-2019-2《Java程序设计》第四周学习总结
20175204 张湲祯 2018-2019-2<Java程序设计>第四周学习总结 教材学习内容总结 -第五章子类与继承要点: -子类与父类: 1.通过使用关键字extends来定义一个类 ...