bzoj4034 树上操作
Description
Input
Output
对于每个询问操作,输出该询问的答案。答案之间用换行隔开。
Sample Input
1 2 3 4 5
1 2
1 4
2 3
2 5
3 3
1 2 1
3 5
2 1 2
3 3
Sample Output
9
13
HINT
用树状数组+DFS序
我们先用一个树状数组维护每一个点(的DFS序)到根节点的值,对于第一个操作,如果把x这个点+k,相当于把以x为根的子树的所有点都加上k,因为这棵子树的DFS序是连续的,所以可以用树状数组维护。而对于第二个操作,讲x的个点和其子树都+k,我们可以先假设,如果只往根节点+k,那么查询每一个点时,就相当于加上了其深度depth*k。如果要往其他点+k,我们可以令开一个树状数组,维护以x为根节点的子树的+k,然后,答案就是第一个树状数组+(depth当前点-depthx)*第二课树状数组。但是,我们在查询时并不知道depthx是什么,因此,在第二个操作时,让第一颗树状数组减去(depthx-1)*k。
#include <iostream>
#include <cstdlib>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <queue>
#define REP(i,k,n) for(long long i=k;i<=n;i++)
#define in(a) a=read()
#define MAXN 100010
using namespace std;
inline long long read(){
long long x=,f=;
char ch=getchar();
for(;!isdigit(ch);ch=getchar())
if(ch=='-')
f=-;
for(;isdigit(ch);ch=getchar())
x=x*+ch-'';
return x*f;
}
queue <long long> Q;
long long n,m;
long long total=,head[MAXN],nxt[MAXN<<],to[MAXN<<];
long long l[MAXN],r[MAXN],depth[MAXN],dfn[MAXN],cnt;
long long tree[][MAXN<<];
long long arr[MAXN];
long long lowbit(long long k){
return k & -k;
}
inline void adl(long long a,long long b){
total++;
to[total]=b;
nxt[total]=head[a];
head[a]=total;
return ;
}
void dfs(long long u,long long fa){
dfn[u]=l[u]=++cnt;
for(long long e=head[u];e;e=nxt[e])
if(to[e]!=fa){
depth[to[e]]=depth[u]+;
dfs(to[e],u);
}
r[u]=cnt;
}
inline void add(long long f,long long s,long long k){
for(long long i=s;i<=n;i+=lowbit(i))
tree[f][i]+=k;
return ;
}
inline long long query(long long f,long long s){
long long sum=;
for(long long i=s;i;i-=lowbit(i))
sum+=tree[f][i];
return sum;
}
int main(){
in(n),in(m);
REP(i,,n)
in(arr[i]);
long long a,b;
REP(i,,n-)
in(a),in(b),adl(a,b),adl(b,a);
depth[]=;
dfs(,);
REP(i,,n)
add(,l[i],arr[i]),add(,r[i]+,-arr[i]);
long long pos,x;
REP(i,,m){
in(pos),in(a);
if(pos==) in(x),add(,l[a],x),add(,r[a]+,-x);
if(pos==) in(x),add(,l[a],x),add(,r[a]+,-x),add(,l[a],-x*(depth[a]-)),add(,r[a]+,x*(depth[a]-));
if(pos==) printf("%lld\n",query(,l[a])*depth[a]+query(,l[a]));
}
return ;
}
/*
5 5
1 2
1 4
2 3
2 5
*/
bzoj4034 树上操作的更多相关文章
- bzoj4034 树上操作 树链剖分+线段树
题目传送门 题目大意: 有一棵点数为 N 的树,以点 1 为根,且树点有权.然后有 M 个操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中所有 ...
- 【BZOJ4034】[HAOI2015]树上操作 树链剖分+线段树
[BZOJ4034][HAOI2015]树上操作 Description 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 ...
- bzoj千题计划242:bzoj4034: [HAOI2015]树上操作
http://www.lydsy.com/JudgeOnline/problem.php?id=4034 dfs序,树链剖分 #include<cstdio> #include<io ...
- bzoj4034[HAOI2015]树上操作 树链剖分+线段树
4034: [HAOI2015]树上操作 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 6163 Solved: 2025[Submit][Stat ...
- 树剖||树链剖分||线段树||BZOJ4034||Luogu3178||[HAOI2015]树上操作
题面:P3178 [HAOI2015]树上操作 好像其他人都嫌这道题太容易了懒得讲,好吧那我讲. 题解:第一个操作和第二个操作本质上是一样的,所以可以合并.唯一值得讲的点就是:第二个操作要求把某个节点 ...
- bzoj4034: [HAOI2015]树上操作(树剖)
4034: [HAOI2015]树上操作 题目:传送门 题解: 树剖裸题: 麻烦一点的就只有子树修改(其实一点也不),因为子树编号连续啊,直接改段(记录编号最小和最大) 开个long long 水模版 ...
- HAOI2015 树上操作
HAOI2015 树上操作 题目描述 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个操作,分为三种:操作 1 :把某个节点 x 的点权增加 a .操作 2 :把某个节点 x 为根 ...
- P3178 [HAOI2015]树上操作
P3178 [HAOI2015]树上操作 思路 板子嘛,其实我感觉树剖没啥脑子 就是debug 代码 #include <bits/stdc++.h> #define int long l ...
- bzoj 4034: [HAOI2015]树上操作 树链剖分+线段树
4034: [HAOI2015]树上操作 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 4352 Solved: 1387[Submit][Stat ...
随机推荐
- How to read source code[repost]
https://github.com/benjycui/benjycui.github.io/blob/master/posts/how-to-read-open-source-javascript- ...
- ACM-ICPC北京赛区2018重现赛 A题
题目链接:http://hihocoder.com/contest/icpcbeijing2018/problem/1 具体思路:dfs,判断矛盾就可以了. AC代码: #include<ios ...
- Sublime text 3中文汉化教程
想弄个中文版的sublime,居然可以不用重新下载汉化包或者重新下载简体中文版了~而是只需要安装个插件即可! 工具/原料 电脑 sublime text3编辑器 方法/步骤 启动并进入s ...
- isolation forest进行异常点检测
一.简介 孤立森林(Isolation Forest)是另外一种高效的异常检测算法,它和随机森林类似,但每次选择划分属性和划分点(值)时都是随机的,而不是根据信息增益或者基尼指数来选择.在建树过程中, ...
- 每天一条linux命令(1):ls命令
ls命令是linux下最常用的命令.ls命令就是list的缩写缺省下ls用来打印出当前目录的清单如果ls指定其他目录那么就会显示指定目录里的文件及文件夹清单. 通过ls 命令不仅可以查看linu ...
- 细说show slave status参数详解(最全)【转】
在搭建好mysql主从之后,我们一般在从库上通过命令 show slave status\G 来查看主从的状态,会有很多的参数,接下来笔者就带大家好好的了解这些参数 root@localhost (n ...
- linux的curl用法【转】
每分钟访问云签到任务执行页面.顺便记录了下curl的用法.以下内容摘自阮一峰博客. 一.查看网页源码 直接在curl命令后加上网址,就可以看到网页源码.我们以网址www.sina.com为例(选择该网 ...
- 用dom4j操作xml文件
XML的全称是eXtensible Markup Language,即“可扩展标记语言”.XML文件的作用主要是数据存储,文件配置,数据传输. html与xml的区别是:①html语法松散,xml语法 ...
- Java容器概述
如果一个程序只包含固定数量的且其生命期都是己知的对象. 那么这是一个非常简单的程序. 通常,程序总是根据运行时才知道的某些条件去创建新对象.在此之前,不会知道所需对象的数量,甚至不知道确切的类型.为解 ...
- hdu 1907(Nim博弈)
John Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Total Submis ...