4034: [HAOI2015]树上操作
4034: [HAOI2015]树上操作
思路:
树链剖分。操作:单点修改,路径查询,子树修改。
代码:
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<iostream>
#include<cmath>
#include<cctype> using namespace std; const int N = ;
typedef long long LL; struct Edge{
int to,nxt;
Edge() {}
Edge(int a,int b) {to = a,nxt = b;}
}e[N<<];
int head[N],tot;
LL sum[N<<],tag[N<<],w[N],data[N];
int pos[N],siz[N],son[N],bel[N],deth[N],fa[N];
int tn; inline int read() {
int x = ,f = ;char ch = getchar();
for (; !isdigit(ch); ch=getchar()) if(ch=='-') f = -;
for (; isdigit(ch); ch=getchar()) x = x*+ch-'';
return x * f;
}
void add_edge(int u,int v) {
e[++tot] = Edge(v,head[u]);head[u] = tot;
e[++tot] = Edge(u,head[v]);head[v] = tot;
}
void dfs1(int u,int pa) {
siz[u] = ;
deth[u] = deth[pa] + ;
fa[u] = pa;
for (int i=head[u]; i; i=e[i].nxt) {
int v = e[i].to;
if (v==pa) continue;
dfs1(v,u);
siz[u] += siz[v];
if (!son[u] || siz[son[u]]<siz[v]) son[u] = v;
}
}
void dfs2(int u,int top) {
bel[u] = top;
pos[u] = ++tn;
data[pos[u]] = w[u];
if (!son[u]) return;
dfs2(son[u],top);
for (int i=head[u]; i; i=e[i].nxt) {
int v = e[i].to;
if (v==fa[u] || v==son[u]) continue;
dfs2(v,v);
}
} #define lson l,mid,rt<<1
#define rson mid+1,r,rt<<1|1 void pushup(int rt) {
sum[rt] = sum[rt<<] + sum[rt<<|];
}
void pushdown(int rt,int len) {
if (tag[rt]) {
sum[rt<<] += 1ll * tag[rt] * (len-len/);tag[rt<<] += tag[rt];
sum[rt<<|] += 1ll * tag[rt] * (len/);tag[rt<<|] += tag[rt];
tag[rt] = ;
}
}
void build(int l,int r,int rt) {
if (l==r) {
sum[rt] = data[l];
return ;
}
int mid = (l + r) / ;
build (lson);
build (rson);
pushup(rt);
}
void update(int l,int r,int rt,int L,int R,LL x) {
if (L <= l && r <= R) {
sum[rt] += 1ll * (r - l + ) * x;
tag[rt] += x;
return ;
}
pushdown(rt,r-l+);
int mid = (l + r) / ;
if (L <= mid) update(lson,L,R,x);
if (R > mid) update(rson,L,R,x);
pushup(rt);
}
LL query(int l,int r,int rt,int L,int R) {
if (L <= l && r <= R) {
return sum[rt];
}
int mid = (l + r) / ;
LL ret = ;
pushdown(rt,r-l+);
if (L <= mid) ret += query(lson,L,R);
if (R > mid) ret += query(rson,L,R);
return ret;
}
void Ask(int x,int y) {
LL ans = ;
while (bel[x] != bel[y]) {
if (deth[bel[x]] < deth[bel[y]]) swap(x,y);
ans += query(,tn,,pos[bel[x]],pos[x]);
x = fa[bel[x]];
}
if (deth[x] < deth[y]) swap(x,y);
ans += query(,tn,,pos[y],pos[x]);
printf("%lld\n",ans);
}
int main() {
int n = read(),m = read();
for (int i=; i<=n; ++i) w[i] = read();
for (int i=; i<n; ++i) {
int u = read(),v = read();
add_edge(u,v);
}
dfs1(,);
dfs2(,);
build(,tn,);
LL a;
while (m--) {
int opt = read(),x = read();
if (opt == ) {
a = read();
update(,tn,,pos[x],pos[x],a);
}
else if (opt==) {
a = read();
update(,tn,,pos[x],pos[x]+siz[x]-,a);
}
else Ask(x,);
}
return ;
}
4034: [HAOI2015]树上操作的更多相关文章
- bzoj 4034: [HAOI2015]树上操作 树链剖分+线段树
4034: [HAOI2015]树上操作 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 4352 Solved: 1387[Submit][Stat ...
- bzoj 4034: [HAOI2015]树上操作 (树剖+线段树 子树操作)
4034: [HAOI2015]树上操作 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 6779 Solved: 2275[Submit][Stat ...
- BZOJ.4034 [HAOI2015]树上操作 ( 点权树链剖分 线段树 )
BZOJ.4034 [HAOI2015]树上操作 ( 点权树链剖分 线段树 ) 题意分析 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 ...
- [BZOJ]4034: [HAOI2015]树上操作
[HAOI2015]树上操作 传送门 题目大意:三个操作 1:a,b,c b节点权值+c 2:a,b,c 以b为根的子树节点权值全部+c 3:a,b 查询b到根路径的权值和. 题解:树链剖分 操作1 ...
- bzoj 4034 [HAOI2015]树上操作 入栈出栈序+线段树 / 树剖 维护到根距离和
题目大意 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中所有点的点权都 ...
- BZOJ 4034 [HAOI2015]树上操作(欧拉序+线段树)
题意: 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中所有点的点权都增 ...
- BZOJ 4034: [HAOI2015]树上操作 [欧拉序列 线段树]
题意: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中所有点的点权都增加 a . 操作 3 :询问某个节点 x 到根的路径中所有点的点权和. 显然树链剖分可做 ...
- 4034. [HAOI2015]树上操作【树链剖分】
Description 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中 ...
- bzoj 4034: [HAOI2015]树上操作——树链剖分
Description 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中 ...
随机推荐
- 浅谈SQL Server中的事务日志(一)----事务日志的物理和逻辑构架
简介 SQL Server中的事务日志无疑是SQL Server中最重要的部分之一.因为SQL SERVER利用事务日志来确保持久性(Durability)和事务回滚(Rollback).从而还部分确 ...
- 压力测试工具ab的使用
ab是Apache自带的HTTP压力测试工具,全称是ApacheBench 路径为\Apache\bin\ab.exe 参数文档: http://httpd.apache.org/docs/2.2/p ...
- input-file类型accept 属性对性能的影响
上传图片的时候,有时会加一些限制,如下,进行上传类型的过滤,如 <input type="file" name="pic" id="pic&qu ...
- 触发transition的几种方式--转
鼠标单击 获取焦点 或元素发生任何改变,怎么说呢,目前的理解是,元素发生了什么改变,使得它跟以前不一样了.比如同样是p元素,先有一个样式.后来这个p被hover了.被focus了.或者通过另外一条途径 ...
- 屏蔽firefox浏览器连接失败页面的广告
现象 最近一直在使用firefox浏览器(版本:57.0.1(64位)),同步书签特别方便,但是最近发现当访问的一个不存在的网址时,连接失败页面竟然有广告!firefox不是号称没有广告吗? 分析 F ...
- 广搜,深搜,单源最短路径,POJ(1130),ZOJ(1085)
题目链接: http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=85 http://poj.org/problem?id=1130 这 ...
- 2018年第九届蓝桥杯【C++省赛B组】第四题 测试次数
x星球的居民脾气不太好,但好在他们生气的时候唯一的异常举动是:摔手机.各大厂商也就纷纷推出各种耐摔型手机.x星球的质监局规定了手机必须经过耐摔测试,并且评定出一个耐摔指数来,之后才允许上市流通.x星球 ...
- 利用python的numpy创建矩阵并对其赋值
创建一个3X3的矩阵并对其赋值: x = numpy.array([[1,2,3],[4,5,6],[7,8,9]]) print x print x.shape 运行结果: [[ ] [ ] [ ] ...
- css隐藏元素的六类13种方法
隐藏元素的方法 隐藏元素的方法可以总结为六类:直接隐藏.对溢出内容隐藏.对元素透明度进行调整.将元素移除当前屏幕.对元素的层级关系进行调整.对元素进行裁剪 只有对元素的透明度进行调整才可以点击,其余都 ...
- prepareStatament和Statement和callableStatement的区别
关系与区别 Statement.PreparedStatement和CallableStatement都是接口(interface) Statement 1.Statement接口提供了执行语句和获取 ...