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 ...
随机推荐
- Numpy系列(十)- 掩码数组
简介 有时候数据集中存在缺失.异常或者无效的数值,我们可以标记该元素为被屏蔽(无效)状态. import numpy as np import numpy.ma as ma x = np.array( ...
- 网页三剑客之JS
1.javascrapt介绍 js概述 JavaScript是运行在浏览器端的脚步语言,JavaScript主要解决的是前端与用户交互的问题,包括使用交互与数据交互. JavaScript是浏览器解释 ...
- 把 Nginx 创建为 Windows 的一个服务
译序:Nginx 不是为 Windows 而写.Nginx 是用在软件的工作环境中的.但软件开发环境一般都是 Windows,有时调试的需要也要装 Nginx,但 Nginx 并没给 Windows ...
- Linux中执行C++程序
参考:https://blog.csdn.net/qq_31125955/article/details/79343498 https://blog.csdn.net/weixin_35477207/ ...
- secureCRT免密码登陆Linux
转自:http://blog.csdn.net/wangquannetwork/article/details/46062675 1.实现原理: 通过CRT生成的密钥对,把公钥上传到Linux服务器指 ...
- Django之验证码
一.自己生成验证码 二.极验科技互动验证码 使用前步骤:下载官网文件——pip install geetest——引入其封装的js模块 代码分为三段:生成验证码——显示验证码——验证验证码. from ...
- LOJ 3049: 洛谷 P5284: 「十二省联考 2019」字符串问题
题目传送门:LOJ #3049. 题意简述: 给定一个长度为 \(n\) 的母串 \(S\). 有 \(n_a\) 个 A 类串,都是 \(S\) 的子串,以区间的形式给出. 有 \(n_b\) 个 ...
- CF1119C Ramesses and Corner Inversion
题目地址:CF1119C Ramesses and Corner Inversion 将两个矩阵异或起来,为 \(1\) 的位置就是需要修改的位置 注意到每一次操作都会导致两行和两列上有两个数被修改 ...
- 【easy】112.path sum 113.-----------------
求是否有从根到叶的路径,节点和等于某个值. /** * Definition for a binary tree node. * struct TreeNode { * int val; * Tree ...
- 20175226 2018-2019-2 《Java程序设计》第四周学习总结
20175226 2018-2019-2 <Java程序设计>第四周学习总结 教材学习内容总结 子类与父类 格式class 子类名 extends 父类名 Object类是所有类的祖先类 ...