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 ...
随机推荐
- html5优分期大学生分期购物商城模板
链接:http://pan.baidu.com/s/1dEUAzBz 密码:j150
- [Leetcode] Sum 系列
Sum 系列题解 Two Sum题解 题目来源:https://leetcode.com/problems/two-sum/description/ Description Given an arra ...
- 用Centos7搭建小微企业Samba文件共享服务器【转】
转自 用Centos7搭建小微企业Samba文件共享服务器 - 今日头条(www.toutiao.com)http://www.toutiao.com/i6436937837660078593/ 最近 ...
- 【转载】C#异常Retry通用类
//Retry机制 public static class Retry { /// <summary> /// 重试零个参数无返回值的方法 /// </summary> /// ...
- CentOS7 安装python库(numpy、scipy、matplotlib、scikit-learn、tensorflow)
0.1准备工作 安装好CentOS7,配置好网络,确保网络畅通. 0.2root授权 首先:当前用户为kaid # vim /etc/sudoers 在root ALL=(ALL) ALL之后添加: ...
- SSL与HTTPS,HTTP有什么联系
有人问:http和https有什么区别? HTTP,全称"Hyper Text Transfer Protocol",是从浏览器访问网站时使用的默认协议.由于浏览器到网站之间的数据 ...
- (转)Opencv卷积操作
转自:http://www.2cto.com/kf/201312/267308.html Mask Operation filter2D函数 Last Edit 2013/12/24 所谓的Mask ...
- Mysql的刷脏页问题
平时的工作中,不知道你有没有遇到过这样的场景,一条 SQL 语句,正常执行的时候特别快,但是有时也不知道怎么回事,它就会变得特别慢,并且这样的场景很难复现,它不只随机,而且持续时间还很短. 当内存数据 ...
- jmeter-----如何安装插件管理?
1.下载插件管理jar文件,http://www.jmeter-plugins.org/wiki/PluginsManager/ 2. 拷贝这jar文件到 \lib\ext文件夹里 3. 重新打开JM ...
- openldap quick start guide
openldap 2.4 在centos 7 x64系统上部署 1 下载源码编译解压tar -xvf xx ./configure make && make install 2 更改配 ...