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 ...
随机推荐
- 【nginx+tomcat集群】Nginx1.12.2+Tomcat7集群+负载均衡+Session共享
今天想着将项目优化一下,就想的实现集群分布,在本机测试:利用nginx+tomcat实现 通过上一篇博客(http://www.cnblogs.com/qlqwjy/p/8535235.html),N ...
- bootstrap通过ajax请求JSON数据后填充到模态框
1. JSP页面中准备模态框 <!-- 详细信息模态框(Modal) --> <div> <div class="modal fade" id=& ...
- Metlnfo CMS全版本漏洞收集
根据https://www.seebug.org/appdir/MetInfo 进行书写. [版本:Metlnfo 4.0] 漏洞标题:Metlnfo cms任意用户密码修改 漏洞文件:member/ ...
- [001] leap_stage
[Description] There is a number in each stages that indicates the most stages you can leap up. Now, ...
- 使用xbee连接地面站和飞控
Zigbee是一种短距离.低功耗的近距离无线组网通讯技术,主要适用于自动控制和远程控制领域,可以嵌入各种设备. DIGI的ZigBee产品XBee小型但却是一个功能完善的ZigBee收发器(即接收器/ ...
- ssh登录时较慢的解决方法
ssh在登录的时候,通常都会经过DNS的反向解析,过程为: IP --> (反向DNS) --> hostname --> (DNS) --> IP 然后匹配开头申请的和最后得 ...
- leetcode 之Search in Rotated Sorted Array(三)
描述 Suppose a sorted array is rotated at some pivot unknown to you beforehand. (i.e., 0 1 2 4 5 6 ...
- HDU3974 Assign the task(多叉树转换为线段+线段树区间染色)
题目大意:有n个人,给你他们的关系(老板和员工),没有直属上司的人就是整个公司的领导者,这意味着n个人形成一棵树(多叉树).当一个人被分配工作时他会让他的下属也做同样的工作(并且立即停止手头正在做的工 ...
- 如何关闭WordPress后台的主题、插件、版本更新通知?
由于WordPress 更新速度非常快,不论是主题 插件或是版本,每个月少说要执行个好几次,因为更新快,所以WordPress后台加入了更新通知,提醒使用者有新版本了,可以进行插件.主题或是系统更新, ...
- 搭建简单的CGI应用程序
原文来源于<核心编程3>第10章web编程 一.静态文件+脚本文件 1.首先开启cgiweb服务器 python2 -m CGIHTTPServer 8000 看到如下反应 2.服务器目录 ...