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 为根的子树中 ...
随机推荐
- SQL Server编程(02)自定义函数
在编程过程中,我们通常把特定的功能语句块封装称函数,方便代码的重用.我们可以在SQL Server中自定义函数,根据函数返回值的区别,我们自定义的函数分两种:标量值函数和表值函数. 自定义函数的优点: ...
- spring-boot-note
1 java配置和注解配置相结合,不需要任何的xml配置即可 2 spring tool suite 3 src/main/resources/banner.txt http://patorjk.co ...
- 理解Linux系统/etc/init.d目录和/etc/rc.local脚本
一.关于/etc/init.d 如果你使用过Linux系统,那么你一定听说过init.d目录.这个目录到底是干嘛的呢?它归根结底只做了一件事情,但这件事情非同小可,是为整个系统做的,因此它非常重 ...
- Java——字符集:Charset
- Apache源码包安装和子配置文件介绍--update.2014-12-5
安装apache: 官网:http://httpd.apache.org/download.cgi#apache24 1.wget http://mirror.bit.edu.cn/apache//h ...
- AOP PostSharp
using System; using System.Collections.Generic; using System.Linq; using System.Text; using PostShar ...
- Jsp与servlet的区别
Jsp与servlet的区别 2011-12-09 16:27:47 分类: Java 1.jsp经编译后就变成了Servlet.(JSP的本质就是Servlet,JVM只能识别java的类,不能识 ...
- mssql手工注入
判断注入点: 1.数字型 http://www.targer.com/article.aspx?id=1 http://www.targer.com/article.aspx?id=1' http:/ ...
- 从HTML原型到jsp页面完美转型攻略(教你即使不会写代码也能弄出漂亮的网页)
大家都知道软件项目(web)开发之前都要先做原型设计,而我们使用的比较多的一款原型设计软件就是Axure rp了.在Axure rp上画原型不需要任何编码能力,而且生成的原型可以在浏览器上运行.除了没 ...
- Linux服务器管理: RPM包
服务安装类型主要分两种: RPM安装和源码包编译安装: 1.RPM包查看: rpm -qa | grep 包名 用chkconfig --list 查看服务自启动命令 只对RPM包安装的服务生效 ...