BZOJ4034——[HAOI2015]T2
1、题目大意:用一个数据结构支持树的点修改和子树修改、树上路径和
2、分析:树链剖分裸题
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
using namespace std;
#define M 1000000
#define LL long long
LL Size[M], value[M], Top[M], Fa[M], Height[M], num[M], left[M], right[M];
LL tot, ST_tot;
LL son[M], head[M], Next[M];
LL n, m;
LL q[M], lazy[M];
void init(){
memset(head, -1, sizeof(head));
memset(lazy, 0, sizeof(lazy));
tot = ST_tot = 0;
Top[1] = 1;
}
void pushdown(LL l, LL r, LL o){
LL mid = (l + r) / 2;
q[2 * o] += (mid + 1 - l) * lazy[o];
q[2 * o + 1] += (r - mid) * lazy[o];
lazy[2 * o] += lazy[o];
lazy[2 * o + 1] += lazy[o];
lazy[o] = 0;
}
void add(LL l, LL r, LL o, LL x, LL y, LL z){
if(x <= l && r <= y){
lazy[o] += z;
q[o] += (r - l + 1) * z;
return;
}
pushdown(l, r, o);
LL mid = (l + r) / 2;
if(x <= mid) add(l, mid, 2 * o, x, y, z);
if(y > mid) add(mid + 1, r, 2 * o + 1, x, y, z);
q[o] = q[2 * o] + q[2 * o + 1];
}
LL query(LL l, LL r, LL o, LL x, LL y){
if(x <= l && r <= y) return q[o];
pushdown(l, r, o);
LL mid = (l + r) / 2, ret = 0;
if(x <= mid) ret += query(l, mid, 2 * o, x, y);
if(y > mid) ret += query(mid + 1, r, 2 * o + 1, x, y);
return ret;
}
void insert(LL x, LL y){
tot ++;
son[tot] = y;
Next[tot] = head[x];
head[x] = tot;
}
void dfs1(LL x, LL fa, LL height){
Fa[x] = fa;
Height[x] = height;
Size[x] = 1;
for(LL i = head[x]; i != -1; i = Next[i]) if(son[i] != fa){
dfs1(son[i], x, height + 1);
Size[x] += Size[son[i]];
}
}
void dfs2(LL x, LL fa){
++ ST_tot;
left[x] = ST_tot;
num[x] = ST_tot;
add(1, n, 1, ST_tot, ST_tot, value[x]);
LL o = 0, ss = 0;
for(LL i = head[x]; i != -1; i = Next[i]) if(son[i] != fa){
if(Size[son[i]] > ss){
ss = Size[son[i]];
o = i;
}
}
if(o != 0){
Top[son[o]] = Top[x];
dfs2(son[o], x);
}
for(LL i = head[x]; i != -1; i = Next[i]) if(son[i] != fa && o != i){
Top[son[i]] = son[i];
dfs2(son[i], x);
}
right[x] = ST_tot;
}
void real_add(LL x, LL y){
add(1, n, 1, left[x], right[x], y);
}
void real_add1(LL x, LL y){
add(1, n, 1, num[x], num[x], y);
}
LL real_query(LL x){
LL y = 1;
LL ret = 0;
while(Top[x] != Top[y]){
if(Height[Top[x]] < Height[Top[y]]) swap(x, y);
ret += query(1, n, 1, num[Top[x]], num[x]);
x = Fa[Top[x]];
}
if(Height[x] < Height[y]) swap(x, y);
ret += query(1, n, 1, num[y], num[x]);
return ret;
}
int main(){
scanf("%lld%lld", &n, &m);
for(LL i = 1; i <= n; i ++) scanf("%lld", &value[i]);
init();
for(LL i = 1; i < n; i ++){
LL x, y;
scanf("%lld%lld", &x, &y);
insert(x, y);
insert(y, x);
}
dfs1(1, 0, 1);
dfs2(1, 0);
for(LL i = 1; i <= m; i ++){
LL op, x, a;
scanf("%lld", &op);
if(op == 1){
scanf("%lld%lld", &x, &a);
real_add1(x, a);
}
else if(op == 2){
scanf("%lld%lld", &x, &a);
real_add(x, a);
}
else{
scanf("%lld", &x);
printf("%lld\n", real_query(x));
}
}
return 0;
}
BZOJ4034——[HAOI2015]T2的更多相关文章
- bzoj4034: [HAOI2015]T2
4034: [HAOI2015]T2 Time Limit: 10 Sec Memory Limit: 256 MB Submit: 2684 Solved: 843 Description 有一 ...
- [BZOJ4034] [HAOI2015] T2 (树链剖分)
Description 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中所 ...
- 【DFS序】【线段树】bzoj4034 [HAOI2015]T2
分开维护树的入栈序和出栈序,用两棵线段树.回答时就是用一颗的减去另一棵的. #include<cstdio> #include<algorithm> using namespa ...
- bzoj 4034 [HAOI2015] T2(树链剖分,线段树)
4034: [HAOI2015]T2 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1536 Solved: 508[Submit][Status] ...
- Bzoj 4034: [HAOI2015]T2 树链剖分,子树问题,dfs序
4034: [HAOI2015]T2 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1841 Solved: 598[Submit][Status] ...
- BZOJ 4034: [HAOI2015]T2( 树链剖分 )
树链剖分...子树的树链剖分序必定是一段区间 , 先记录一下就好了 ------------------------------------------------------------------ ...
- bzoj 4034: [HAOI2015]T2
4034: [HAOI2015]T2 Description 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操 ...
- 【bzoj4034】[HAOI2015]T2
siz[v]表示以v为根的子树的节点数 top[v]表示v所在的重链的顶端节点 fa[v]表示v的父亲 pos[v]表示v的父边标号 mx[v]表示v的子树中边的标号最大的那条边 参考:http:// ...
- 数据结构(树链剖分):BZOJ 4034: [HAOI2015]T2
Description 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中 ...
随机推荐
- 在Android上实现使用Facebook登录(基于Facebook SDK 3.5)
准备工作: 1. Facebook帐号,国内开发者需要一个vpn帐号(网页可以浏览,手机可以访问) 2. 使用Facebook的SDK做应用需要一个Key Hashes值. 2 ...
- MFC学习-第2,3课 MFC框架的运行机制
转自:http://blog.163.com/zhigang0633@126/blog/static/38790491200822711526168/ 讲述MFC AppWizard的原理与MFC程序 ...
- phpcms响应式布局导航条
- Python2.7安装(win7)
Python可在官方网站直接下,或者百度一下Python2.7下载,这里推荐使用2.7而不是3.3,比较适合初学者 工具/原料 win7系统 python2.7安装包 方法/步骤 1.从官网下载最新的 ...
- select()
select(),确定一个或多个套接口的状态,本函数用于确定一个或多个套接口的状态,对每一个套接口,调用者可查询它的可读性.可写性及错误状态信息,用fd_set结构来表示一组等待检查的套接口,在调用返 ...
- 20145212 《Java程序设计》第7周学习总结
20145212 <Java程序设计>第7周学习总结 教材学习内容总结 时间的度量 格林威治时间(GMT):通过观察太阳而得,因为地球公转轨道为椭圆形且速度不一,本身自传减速而造成误差. ...
- 20145212《Java程序设计》实验报告一:Java开发环境的熟悉(Windows+IDE)
20145212<Java程序设计>实验报告一:Java开发环境的熟悉(Windows+IDE) 实验内容及步骤 1.命令行下的JAVA程序开发 建立并进入实验目录: 撰写简单的Hello ...
- Azure媒体服务 直播延迟的原因解析
当我们使用媒体服务的直播功能,会发现有时候会有较大的延迟,而延迟的产生和客户端以及推送软件的配置也有关系,本文以Wirecast为例进行分析 Encoder导致的延迟:在编码这一步骤的时候,它会消耗机 ...
- js返回顶部
1. function scrollTop(){ $(},); } 2. $("#side-bar .gotop").click(function(){ $(},); //返回顶部 ...
- win8.1企业版 IIS8.5 安装php5.5.18详细图文
最近为了做测试需要在电脑上安装php 环境如下 系统 win8.1 企业版 IIS 8.5 PHP:5.5.18 php-5.5.18-nts-Win32-VC11-x64 完整文件名 注意IIS 下 ...