Description

一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w。我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t : 把结点u的权值改为t II. QMAX u v: 询问从点u到点v的路径上的节点的最大权值 III. QSUM u v: 询问从点u到点v的路径上的节点的权值和 注意:从点u到点v的路径上的节点包括u和v本身
Input

输入的第一行为一个整数n,表示节点的个数。接下来n – 1行,每行2个整数a和b,表示节点a和节点b之间有一条边相连。接下来n行,每行一个整数,第i行的整数wi表示节点i的权值。接下来1行,为一个整数q,表示操作的总数。接下来q行,每行一个操作,以“CHANGE u t”或者“QMAX u v”或者“QSUM u v”的形式给出。 对于100%的数据,保证1<=n<=30000,0<=q<=200000;中途操作中保证每个节点的权值w在-30000到30000之间。
Output

对于每个“QMAX”或者“QSUM”的操作,每行输出一个整数表示要求输出的结果。
Sample Input
4
1 2
2 3
4 1
4 2 1 3
12
QMAX 3 4
QMAX 3 3
QMAX 3 2
QMAX 2 3
QSUM 3 4
QSUM 2 1
CHANGE 1 5
QMAX 3 4
CHANGE 3 6
QMAX 3 4
QMAX 2 4
QSUM 3 4
Sample Output
4
1
2
2
10
6
5
6
5
16

裸树链剖分,我就不多说了,附入门教程

 const
maxn=;
type
node=record
son:array[..]of longint;
sum,max,left,right,mid:longint;
end;
var
n,m,num,tot,xx,ll,rr,goal:longint;
tree:array[..maxn*]of node;
first,fa,dep,son,size,w,top,root:array[..maxn]of longint;
next,last:array[..maxn*]of longint; procedure insert(x,y:longint);
begin
inc(num);
last[num]:=y;
next[num]:=first[x];
first[x]:=num;
end; procedure dfs1(x,d,f:longint);
var
i:longint;
begin
dep[x]:=d;
fa[x]:=f;
size[x]:=;
i:=first[x];
while i<> do
begin
if last[i]<>f then
begin
dfs1(last[i],d+,x);
if size[last[i]]>size[son[x]] then son[x]:=last[i];
inc(size[x],size[last[i]]);
end;
i:=next[i];
end;
end; procedure build(l,r:longint);
var
now:longint;
begin
inc(tot);
now:=tot;
with tree[now] do
begin
left:=l;
right:=r;
if l=r then exit;
mid:=(l+r)>>;
son[]:=tot+;
build(l,mid);
son[]:=tot+;
build(mid+,r);
end;
end; procedure dfs2(x,t,ww:longint);
var
i:longint;
begin
w[x]:=ww;
top[x]:=t;
if son[x]= then
begin
root[x]:=tot+;
build(,ww);
exit;
end
else
begin
dfs2(son[x],t,ww+);
root[x]:=root[son[x]];
end;
i:=first[x];
while i<> do
begin
if (last[i]<>fa[x]) and (last[i]<>son[x]) then dfs2(last[i],last[i],);
i:=next[i];
end;
end; procedure change(now:longint);
begin
with tree[now] do
begin
if left=right then
begin
sum:=goal;
max:=goal;
exit;
end;
if xx<=mid then change(son[])
else change(son[]);
if tree[son[]].max>tree[son[]].max then max:=tree[son[]].max
else max:=tree[son[]].max;
sum:=tree[son[]].sum+tree[son[]].sum;
end;
end; function getsum(now:longint):longint;
begin
with tree[now] do
begin
if (ll<=left) and (rr>=right) then exit(sum);
if rr<=mid then exit(getsum(son[]));
if ll>mid then exit(getsum(son[]));
exit(getsum(son[])+getsum(son[]));
end;
end; function getmax(now:longint):longint;
var
s:longint;
begin
with tree[now] do
begin
if (ll<=left) and (rr>=right) then exit(max);
if rr<=mid then exit(getmax(son[]));
if ll>mid then exit(getmax(son[]));
getmax:=getmax(son[]);
s:=getmax(son[]);
if s>getmax then getmax:=s;
end;
end; procedure init;
var
i,x,y:longint;
begin
read(n);
for i:= to n- do
begin
read(x,y);
insert(x,y);
insert(y,x);
end;
dfs1(,,);
dfs2(,,);
for i:= to n do
begin
read(goal);
xx:=w[i];
change(root[i]);
end;
end; procedure work;
var
i,ans,s,x,y:longint;
s1,s2:char;
begin
read(m);
for i:= to m do
begin
read(s2);
while s2<>' ' do
begin
s1:=s2;
read(s2);
end;
read(x,y);
case s1 of
'E':begin
goal:=y;
xx:=w[x];
change(root[x]);
end;
'X':begin
ans:=-;
while top[x]<>top[y] do
begin
if dep[top[x]]<dep[top[y]] then
begin
s:=x;x:=y;y:=s;
end;
ll:=;
rr:=w[x];
s:=getmax(root[x]);
if s>ans then ans:=s;
x:=fa[top[x]];
end;
if dep[x]<dep[y] then
begin
s:=x;x:=y;y:=s;
end;
ll:=w[y];
rr:=w[x];
s:=getmax(root[x]);
if s>ans then ans:=s;
writeln(ans);
end;
'M':begin
ans:=;
while top[x]<>top[y] do
begin
if dep[top[x]]<dep[top[y]] then
begin
s:=x;x:=y;y:=s;
end;
ll:=;
rr:=w[x];
inc(ans,getsum(root[x]));
x:=fa[top[x]];
end;
if dep[x]<dep[y] then
begin
s:=x;x:=y;y:=s;
end;
ll:=w[y];
rr:=w[x];
inc(ans,getsum(root[x]));
writeln(ans);
end;
end;
end;
end; begin
init;
work;
end.

1036: [ZJOI2008]树的统计Count - BZOJ的更多相关文章

  1. BZOJ.1036 [ZJOI2008]树的统计Count ( 点权树链剖分 线段树维护和与最值)

    BZOJ.1036 [ZJOI2008]树的统计Count (树链剖分 线段树维护和与最值) 题意分析 (题目图片来自于 这里) 第一道树链剖分的题目,谈一下自己的理解. 树链剖分能解决的问题是,题目 ...

  2. BZOJ 1036: [ZJOI2008]树的统计Count [树链剖分]【学习笔记】

    1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 14302  Solved: 5779[Submit ...

  3. BZOJ 1036: [ZJOI2008]树的统计Count

    1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 14354  Solved: 5802 [Subm ...

  4. bzoj 1036 [ZJOI2008]树的统计Count(树链剖分,线段树)

    1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 10677  Solved: 4313[Submit ...

  5. Bzoj 1036: [ZJOI2008]树的统计Count 树链剖分,LCT

    1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 11102  Solved: 4490[Submit ...

  6. 数据结构(LCT动态树):BZOJ 1036: [ZJOI2008]树的统计Count

    1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 12266  Solved: 4945[Submit ...

  7. BZOJ 1036: [ZJOI2008]树的统计Count( 树链剖分 )

    树链剖分... 不知道为什么跑这么慢 = = 调了一节课啊跪.. ------------------------------------------------------------------- ...

  8. bzoj 1036: [ZJOI2008]树的统计Count 树链剖分+线段树

    1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 16294  Solved: 6645[Submit ...

  9. bzoj 1036: [ZJOI2008]树的统计Count (树链剖分+线段树 点权)

    1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 21194  Solved: 8589[Submit ...

随机推荐

  1. Oracle表空间操作

    -- 查看表空间 SELECT tablespace_name, file_id, file_name, ), )||'M' total_space FROM dba_data_files ORDER ...

  2. Swift使用闭包表达式

    Swift中的闭包表达式很灵活,其标准语法格式如下:{ (参数列表) ->返回值类型 in    语句组}其中,参数列表与函数中的参数列表形式一样,返回值类型类似于函数中的返回值类型,但不同的是 ...

  3. SQL通过日期计算年龄

    首先建立一个表如下: ======================= BirthDay datetime not null Age 通过公式计算得出 ======================= 以 ...

  4. UEditor的使用方法

    文本编辑器程序员都会用到,今天无意中发现UEditor是个好东西,特奉献给大家,并提供下载. 这个编辑器的亮点是可以显示当前输入多少字符,还可以输入多少字符. 新创建的MVC项目,在layout页面里 ...

  5. tip 2:找最小公倍数之Boost

    今天在codewars上面做了一题,kata5的,其中一个实现函数是几个数字的最小公倍数.自己的代码编译虽然也成功了,但是不够简介.看了别人的代码才发现可以直接调用Boost的math模块. 看eff ...

  6. 输入与enter

    #include<iostream> using namespace std; int main() { char a,b,c; while(scanf("%c%c%c" ...

  7. xamarin android——数据绑定到控件(一)

    mono for android 中光标由ICursor 接口标识,该接口公开了操作结果数据集的所有方法.光标的使用非常消耗系统资源,所以不使用时应该光比光标.可以通过StartManagingCur ...

  8. Ueditor中增加迅雷下载支持

    在项目中有遇到需要在Ueditor中加一个链接,迅雷的开头是thunder 会被默认加上http://   最后的 结果就变成了http://thunder://xxxxx 导致用户点击失败: 其实在 ...

  9. 单纯形法C++实现

    作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4156685.html 使用单纯型法来求解线性规划,输入单纯型法的松弛形式,是一个大矩阵,第一 ...

  10. Mysql数据库迁移 Ubuntu14.04

    1. 停止数据库服务 sudo service mysql stop 2. 创建数据迁移目标文件夹(实际应该是挂载到新硬盘上) cd /var/lib ls -l drwx------  6 mysq ...