题解【SP8002】HORRIBLE - Horrible Queries
题解
这是一道线段树的模板题。
题目需要我们维护一个支持区间修改、区间查询的一个数据结构,很容易想到线段树。
然后发现和洛谷上线段树的模板1是同一道题。
由于本题中每个数的初始值都为\(0\),因此我们就不需要建树,直接开始把树上每个结点的值都初始化成\(0\)即可。
修改时寻找指定区间,维护一下\(lazy\ tag\)并更新节点的值即可。
查询时和修改同理,只是把查找更新的区间变成了加上区间的和。
注意:
- 数据有\(T\)组,因此每组数据开头都需要清空数组;
- \(lazy\ tag\)标记下传时要注意最后清空当前节点的\(lazy\ tag\);
- 需要开\(long\ long\)。
代码
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <cctype>
#define int long long
#define itn int
#define gI gi
using namespace std;
inline int gi()
{
int f = 1, x = 0; char c = getchar();
while (c < '0' || c > '9') { if (c == '-') f = -1; c = getchar();}
while (c >= '0' && c <= '9') { x = x * 10 + c - '0'; c = getchar();}
return f * x;
}
int n, ans[100005 << 2], tag[100005 << 2];
inline int ls(int x) {return x << 1;}//左儿子
inline int rs(int x) {return x << 1 | 1;}//右儿子
inline void push_up(int x)//上传标记
{
ans[x] = ans[ls(x)] + ans[rs(x)];//求和
}
inline void pushdown(int p, int l, int r)//下传标记
{
if (tag[p])//如果还有标记
{
ans[ls(p)] = ans[ls(p)] + tag[p] * l;
ans[rs(p)] = ans[rs(p)] + tag[p] * r;//加上和
tag[ls(p)] = tag[ls(p)] + tag[p];
tag[rs(p)] = tag[rs(p)] + tag[p];//加上标记
tag[p] = 0;//清零标记
}
}
void upd(int nl, int nr, int l, int r, int p, int k)//更新操作
{
if (nl <= l && nr >= r)//当前区间包含于要更新的区间
{
ans[p] = ans[p] + (r - l + 1) * k, tag[p] = tag[p] + k;//加上和并记录lazy标记
return;
}
int mid = (l + r) >> 1;
pushdown(p, mid - l + 1, r - mid);//下传lazy标记
if (nl <= mid) upd(nl, nr, l, mid, ls(p), k);//更新左区间
if (nr > mid) upd(nl, nr, mid + 1, r, rs(p), k);//更新右区间
push_up(p);//上传节点
}
int getans(int ql, int qr, int l, int r, int p)//求和操作,与更新同理
{
int sum = 0;
if (ql <= l && qr >= r) return ans[p];
int mid = (l + r) >> 1;
pushdown(p, mid - l + 1, r - mid);
if (ql <= mid) sum = sum + getans(ql, qr, l, mid, ls(p));
if (qr > mid) sum = sum + getans(ql, qr, mid + 1, r, rs(p));
return sum;
}
signed main()
{
int T = gi();
while (T--)//多组数据
{
memset(tag, 0, sizeof(tag));
memset(ans, 0, sizeof(ans));//多组数据记得清空数组
int n = gi(), m = gi();
for (int i = 1; i <= m; i++)
{
int fl = gi();
if(fl == 0)//修改操作
{
int x = gi(), y = gi(), k = gi();
upd(x, y, 1, n, 1, k);
}
else//求和操作
{
int x = gi(), y = gi();
printf("%lld\n", getans(x, y, 1, n, 1));
}
}
}
return 0;//结束
}
题解【SP8002】HORRIBLE - Horrible Queries的更多相关文章
- 【题解】A Horrible Poem
题目大意 给出一个由小写英文字母组成的字符串 S,再给出 q 个询问,要求回答 S 某个子串的最短循环节. 如果字符串 B 是字符串 A 的循环节,那么 A 可以由 B 重复若干次得到. 输入格式 第 ...
- 题解-Codeforces710F String Set Queries
咕了好久没更博客,最近得知可以去冬眠营玩耍,还可以搭顺风车回广州过年 (最近做到的比较有意思的题目:bzoj3958.hihocoder1419) Problem Codeforces-710F--洛 ...
- 题解-------CF1304E 1-Trees and Queries
传送门 题目大意 给你一棵无根树,然后询问Q次,每次把点$x$和点$y$连接,问你从点$a$到点$b$是否有一条长度为$k$的简单路径,每次询问完后会把新添加的边删除. 思路:树上LCA 题目跟201 ...
- Mysql存储引擎之TokuDB以及它的数据结构Fractal tree(分形树)
在目前的Mysql数据库中,使用最广泛的是innodb存储引擎.innodb确实是个很不错的存储引擎,就连高性能Mysql里都说了,如果不是有什么很特别的要求,innodb就是最好的选择.当然,这偏文 ...
- 分形树Fractal tree介绍——具体如何结合TokuDB还没有太懂,先记住其和LSM都是一样的适合写密集
在目前的Mysql数据库中,使用最广泛的是innodb存储引擎.innodb确实是个很不错的存储引擎,就连高性能Mysql里都说了,如果不是有什么很特别的要求,innodb就是最好的选择.当然,这偏文 ...
- Servlet3.0学习总结(二)——使用注解标注过滤器(Filter)
Servlet3.0提供@WebFilter注解将一个实现了javax.servlet.Filter接口的类定义为过滤器,这样我们在web应用中使用过滤器时,也不再需要在web.xml文件中配置过滤器 ...
- MySQL 高性能存储引擎:TokuDB初探
在安装MariaDB的时候了解到代替InnoDB的TokuDB,看简介非常的棒,这里对ToduDB做一个初步的整理,使用后再做更多的分享. 什么是TokuDB? 在MySQL最流行的支持全事务的引擎为 ...
- MySQL-TokuDB:MySQL 高性能存储引擎:TokuDB
ylbtech-MySQL-TokuDB:MySQL 高性能存储引擎:TokuDB 1.返回顶部 1. 在安装MariaDB的时候了解到代替InnoDB的TokuDB,看简介非常的棒,这里对ToduD ...
- Codeforces 556D Restructuring Company
传送门 D. Restructuring Company time limit per test 2 seconds memory limit per test 256 megabytes input ...
随机推荐
- 查看whl包名是否满足系统的条件的命令,以此解决whl包出现“is not a supported wheel on this platform”错误提示的问题
在Ubuntu系统中,使用pip安装whl包时,常常会报如下错误: tensorflow_gpu-1.11.0-cp35-cp35m-manylinux1_x86_64.whl is not a su ...
- 将Python模块转变为命令行工具
问:如何输入命令行就能执行python代码呢? 答:要将python模块转变为命令行工具只用在 setup.py 文件中添加参数entry_points 例如: entry_points={ 'con ...
- SVM-支持向量机(二)非线性SVM分类
非线性SVM分类 尽管SVM分类器非常高效,并且在很多场景下都非常实用.但是很多数据集并不是可以线性可分的.一个处理非线性数据集的方法是增加更多的特征,例如多项式特征.在某些情况下,这样可以让数据集变 ...
- 【Python】表白程序
程序链接:https://www.lanzous.com/i8xj5mh # 打包操作 # 安装pyinstaller # cmd输入 pip install pyinstaller # shift ...
- 论文阅读笔记(二)【IJCAI2016】:Video-Based Person Re-Identification by Simultaneously Learning Intra-Video and Inter-Video Distance Metrics
摘要 (1)方法: 面对不同行人视频之间和同一个行人视频内部的变化,提出视频间和视频内距离同时学习方法(SI2DL). (2)模型: 视频内(intra-vedio)距离矩阵:使得同一个视频更紧凑: ...
- WSO2 ESB XML定义语法(3)
6.Property Mediator 通过Synapse调解的每条消息都可以具有一组关联的属性.Synapse引擎和底层传输在处理的每条消息上设置了许多属性,用户可以操纵这些属性来修改消息流的运行时 ...
- dataTables插件的使用
用到dataTables这个插件还是因为Metronic这个框架里有用到,不然我不会选择它的,为啥呢?就感觉它的文档有点复杂(当然,也有我智商不够用的原因):既然用了,那就说说我遇到的问题吧,以防下次 ...
- Xshell 5
Xshell 5安装步骤(带安装包):http://www.cnblogs.com/ysocean/p/7702243.html
- Vue中v-show和v-if的使用以及区别
个人博客 地址:http://www.wenhaofan.com/article/20190321143330 v-if 1.v-if 根据条件渲染,它会确保在切换过程中条件块内的组件销毁和重建 ...
- google protocol 入门 demo
ubunbu系统下google protobuf的安装 说明: 使用protobuf时需要安装两部分: 第一部分为*.proto文件的编译器,它负责把定义的*.proto文件生成对应的c++类的.h和 ...