ZJ2008树的统计(树链剖分)
type node1=record
go,next:longint;end;
node2=record
l,r,mx,sum:longint;end;
var i,x,y,n,q,tmp,cnt,sz,code:longint;
ch,st:string;
fa:array[..,..] of longint;
v,deep,son,head,pl,belong,vis:array[..] of longint;
e:array[..] of node1;
t:array[..] of node2;
procedure insert(x,y:longint);
begin
inc(cnt);e[cnt].go:=y;e[cnt].next:=head[x];head[x]:=cnt;
inc(cnt);e[cnt].go:=x;e[cnt].next:=head[y];head[y]:=cnt;
end;
procedure dfs1(x:longint);
var i,j:longint;
begin
son[x]:=;vis[x]:=;
for i:= to do
begin
if deep[x]<(<<i) then break;
fa[x,i]:=fa[fa[x,i-],i-];
end;
i:=head[x];
while i<> do
begin
j:=e[i].go;
if vis[j]= then
begin
deep[j]:=deep[x]+;
fa[j,]:=x;
dfs1(j);
inc(son[x],son[j]);
end;
i:=e[i].next;
end;
end;
procedure dfs2(x,chain:longint);
var i,j,k:longint;
begin
k:=;inc(sz);
pl[x]:=sz;belong[x]:=chain;
i:=head[x];
while i<> do
begin
j:=e[i].go;
if (deep[j]>deep[x]) and (son[j]>son[k]) then k:=j;
i:=e[i].next;
end;
if k= then exit;
dfs2(k,chain);
i:=head[x];
while i<> do
begin
j:=e[i].go;
if (deep[j]>deep[x]) and (k<>j) then
dfs2(j,j);
i:=e[i].next;
end;
end;
function lca(x,y:longint):longint;
var i,tmp:longint;
begin
if deep[x]<deep[y] then begin tmp:=x;x:=y;y:=tmp;end;
tmp:=deep[x]-deep[y];
for i:= to do
if (tmp and (<<i)<>) then x:=fa[x,i];
for i:= downto do
if fa[x,i]<>fa[y,i] then
begin
x:=fa[x,i];y:=fa[y,i];
end;
if x=y then exit(x) else exit(fa[x,]);
end;
procedure build(x,y,k:longint);
var mid:longint;
begin
with t[k] do
begin
l:=x;r:=y;
if l=r then exit;
mid:=(l+r)>>;
build(l,mid,k<<);
build(mid+,r,k<<+);
end;
end;
function max(x,y:longint):longint;
begin
if x>y then exit(x) else exit(y);
end;
procedure change(x,y,k:longint);
var mid:longint;
begin
with t[k] do
begin
if l=r then
begin sum:=y;mx:=y;exit;end;
mid:=(l+r)>>;
if x<=mid then change(x,y,k<<)
else change(x,y,k<<+);
sum:=t[k<<].sum+t[k<<+].sum;
mx:=max(t[k<<].mx,t[k<<+].mx);
end;
end;
function getsum(x,y,k:longint):longint;
var mid:longint;
begin
with t[k] do
begin
if (l=x) and (r=y) then exit(sum);
mid:=(l+r)>>;
if x>mid then exit(getsum(x,y,k<<+))
else if y<=mid then exit((getsum(x,y,k<<)))
else exit(getsum(x,mid,k<<)+getsum(mid+,y,k<<+));
end;
end;
function getmx(x,y,k:longint):longint;
var mid:longint;
begin
with t[k] do
begin
if (l=x) and (r=y) then exit(mx);
mid:=(l+r)>>;
if x>mid then exit(getmx(x,y,k<<+))
else if y<=mid then exit(getmx(x,y,k<<))
else exit(max(getmx(x,mid,k<<),getmx(mid+,y,k<<+)));
end;
end;
function solvesum(x,y:longint):longint;
var sum:longint;
begin
sum:=;
while belong[x]<>belong[y] do
begin
inc(sum,getsum(pl[belong[x]],pl[x],));
x:=fa[belong[x],];
end;
inc(sum,getsum(pl[y],pl[x],));
exit(sum);
end;
function solvemx(x,y:longint):longint;
var mx:longint;
begin
mx:=-maxlongint;
while belong[x]<>belong[y] do
begin
mx:=max(mx,getmx(pl[belong[x]],pl[x],));
x:=fa[belong[x],];
end;
mx:=max(mx,getmx(pl[y],pl[x],));
exit(mx);
end;
procedure init;
begin
readln(n);
for i:= to n- do
begin
readln(x,y);insert(x,y);
end;
for i:= to n do read(v[i]);
end;
procedure solve;
begin
build(,n,);
for i:= to n do change(pl[i],v[i],);
readln(q);
for i:= to q do
begin
readln(st);
ch:=copy(st,,pos(' ',st)-);
delete(st,,pos(' ',st));
val(copy(st,,pos(' ',st)-),x,code);
delete(st,,pos(' ',st));
val(st,y,code);
case ch of
'CHANGE':begin
v[x]:=y;
change(pl[x],y,);
end;
'QMAX':begin
tmp:=lca(x,y);
writeln(max(solvemx(x,tmp),solvemx(y,tmp)));
end;
else begin
tmp:=lca(x,y);
writeln(solvesum(x,tmp)+solvesum(y,tmp)-v[tmp]);
end;
end;
end;
end;
begin
init;
dfs1();
dfs2(,);
solve;
end.
作为以后的模版!
ZJ2008树的统计(树链剖分)的更多相关文章
- BZOJ 1036: [ZJOI2008]树的统计Count-树链剖分(点权)(单点更新、路径节点最值、路径求和)模板,超级认真写了注释啊啊啊
1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 23015 Solved: 9336[Submit ...
- 树的统计Count---树链剖分
NEFU专项训练十和十一——树链剖分 Description 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t ...
- BZOJ 1036 树的统计-树链剖分
[ZJOI2008]树的统计Count Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 12904 Solved: 5191[Submit][Status ...
- bzoj1036 树的统计 树链剖分模板
题意:给出树上任意两点,求路径上的值的和与最大值,带单点修改操作 树链剖分思路: 1.对树进行dfs求出点的深度和父亲节点,然后求出轻重儿子(重儿子就是点最多的那个子树,其余都是轻儿子),用一个son ...
- zjoi 2008 树的统计——树链剖分
比较基础的一道树链剖分的题 大概还是得说说思路 树链剖分是将树剖成很多条链,比较常见的剖法是按儿子的size来剖分,剖分完后对于这课树的询问用线段树维护——比如求路径和的话——随着他们各自的链向上走, ...
- BZOJ-1036 树的统计Count 链剖线段树(模板)=(树链剖分+线段树)
潇爷昨天刚刚讲完...感觉得还可以...对着模板打了个模板...还是不喜欢用指针.... 1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec Memory Lim ...
- BZOJ1036[ZJOI2008]树的统计——树链剖分+线段树
题目描述 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t : 把结点u的权值改为t II. QMAX u v ...
- [ZJOI2008]树的统计——树链剖分
本题是一个树链剖分裸题,由于比较菜,老是RE,后来发现是因为使用了全局变量. /************************************************************ ...
- [luogu P2590 ZJOI2008] 树的统计 (树链剖分)
题目描述 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w. 我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t : 把结点u的权值改为t II. QMAX u ...
- 洛谷P2590 [ZJOI2008] 树的统计 [树链剖分]
题目传送门 树的统计 题目描述 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w. 我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t : 把结点u的权值改为t ...
随机推荐
- Netty4.x中文教程系列(四) 对象传输
Netty4.x中文教程系列(四) 对象传输 我们在使用netty的过程中肯定会遇到传输对象的情况,Netty4通过ObjectEncoder和ObjectDecoder来支持. 首先我们定义一个U ...
- CSDN——【低调的草原狼】——Ext4.2学习目录整理
最近在研究ExtJS,发现CSDN中有个博客中一系列文档非常优秀,但是没有对目录进行整理,在此稍作整理,也为以后自己研究打下一个基础: 原文作者:低调的草原狼 目录: 1.ExtJS4.2学习 ...
- HDAO
dx11 hdao10.1 除了dx的sample竟然搜不到什么文档.... 估计去问别人也是让我继续看代码.. ---------------------------------------- 算法 ...
- Directx3D SimpleSample Sample
在d3d 2010 june这个版本里的samples 不知道为什么SimpleSample Sample 这个 它的documents基本等于没有 Starting point for new Di ...
- 引擎设计跟踪(九.10) Max插件更新,地形问题备忘
最近没有大的更新. 最近本来要做max的骨骼/动画导出, 看导出插件代码的时候, 突然想起之前tagent space导出的疑问, 于是确认了一下. http://www.cnblogs.com/cr ...
- CSS中nth-child和nth-of-type的简单使用
ele:nth-child是查找父元素下的子元素,包括子元素类型非ele的,当子元素类型不是ele时,则不会进行任何操作: ele:nth-of-type是查找父元素下的子元素类型为ele的元素,其是 ...
- GDB笔记
GDB是在Linux命令行下对C/C++的程序进行调试常用的一个命令,现将平时记录在本子上的笔记整理如下: 一.断点 断点类型有breakpoints, watchpoints, catchpoint ...
- ubuntu下安装pthread的manpages(man 手册) 在Ubuntu中查看STL帮助
http://blog.csdn.net/leisure512/article/details/4881391 由于学习多线程编程,所以用到pthread,但是man的时候却发现没有pthread函数 ...
- Sina App Engine(SAE)入门教程(6)- memcache使用
Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像.视频.文件以及数据库检索的结果等.简单的说就是将数据调用到内 ...
- VS2010/MFC编程入门之一(VS2010与MSDN安装过程图解)
原文地址: VS2010/MFC编程入门之一(VS2010与MSDN安装过程图解)-软件开发-鸡啄米 http://www.jizhuomi.com/software/139.html 上一讲中鸡 ...