Description

  一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w。我们将以下面的形式来要求你对这棵树完成
一些操作: I. CHANGE u t : 把结点u的权值改为t II. QMAX u v: 询问从点u到点v的路径上的节点的最大权值 I
II. 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

树链剖分模板

 #include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
using namespace std; int head[],num_edge;
int Father[],Weight[];
int Son[],Top[];
int T_NUM[],a[];
int Depth[];
int sum,n,INF,ans;
int TREE[];
char st[];
struct node
{
int to,next;
} edge[];
struct node1
{
int max,sum;
} Segt[];
void add(int u,int v)
{
edge[++num_edge].to=v;
edge[num_edge].next=head[u];
head[u]=num_edge;
}
void dfs1(int x)
{
Weight[x]=;
Depth[x]=Depth[Father[x]]+;
for (int i=head[x]; i!=; i=edge[i].next)
if (edge[i].to!=Father[x])
{
Father[edge[i].to]=x;
dfs1(edge[i].to);
Weight[x]+=Weight[edge[i].to];
if (Son[x]== || Weight[edge[i].to]>Weight[Son[x]])
Son[x]=edge[i].to;
}
} void dfs2(int x,int tp)
{
T_NUM[x]=++sum;
TREE[sum]=a[x];
Top[x]=tp;
if (Son[x]!=)
dfs2(Son[x],tp);
for (int i=head[x]; i!=; i=edge[i].next)
if (edge[i].to!=Son[x] && edge[i].to!=Father[x])
dfs2(edge[i].to,edge[i].to);
} void Build(int node,int l,int r,int a[])
{
if (l==r)
Segt[node].max=Segt[node].sum=a[l];
else
{
int mid=(l+r)/;
Build(node*,l,mid,a);
Build(node*+,mid+,r,a);
Segt[node].max=max(Segt[node*].max,Segt[node*+].max);
Segt[node].sum=Segt[node*].sum+Segt[node*+].sum;
}
} void Update(int node,int l,int r,int x,int k)
{
if (l==r)
Segt[node].max=Segt[node].sum=k;
else
{
mid=(l+r)/;
(x<=mid)
date(node*,l,mid,x,k);
else
Update(node*+,mid+,r,x,k);
Segt[node].max=max(Segt[node*].max,Segt[node*+].max);
Segt[node].sum=Segt[node*].sum+Segt[node*+].sum;
}
} int QueryMax(int node,int l,int r,int l1,int r1)
{
if (r<l1 || l>r1)
return -INF;
if (l1<=l && r<=r1)
return Segt[node].max;
int mid=(l+r)/;
return max(QueryMax(node*,l,mid,l1,r1),
QueryMax(node*+,mid+,r,l1,r1));
} int QuerySum(int node,int l,int r,int l1,int r1)
{
if (r<l1 || l>r1)
return ;
if (l1<=l && r<=r1)
return Segt[node].sum;
int mid=(l+r)/;
return QuerySum(node*,l,mid,l1,r1)+
QuerySum(node*+,mid+,r,l1,r1);
} int GetSum(int x,int y)
{
int fx,fy;
memset(&ans,,sizeof(ans));
fx=Top[x];
fy=Top[y];
while (fx!=fy)
{
if (Depth[fx]<Depth[fy])
swap(fx,fy),swap(x,y);
ans+=QuerySum(,,n,T_NUM[fx],T_NUM[x]);
x=Father[fx],fx=Top[x];
}
if (Depth[x]>Depth[y]) swap(x,y);
return ans+=QuerySum(,,n,T_NUM[x],T_NUM[y]);
} int GetMax(int x,int y)
{
int fy,fx;
memset(&ans,-0x7f,sizeof(ans));
fx=Top[x];
fy=Top[y];
while (fx!=fy)
{
if (Depth[fx]<Depth[fy])
swap(fx,fy),swap(x,y);
ans=max(ans,QueryMax(,,n,T_NUM[fx],T_NUM[x]));
x=Father[fx],fx=Top[x];
}
if (Depth[x]>Depth[y]) swap(x,y);
return max(ans,QueryMax(,,n,T_NUM[x],T_NUM[y]));
} int main()
{
int i,u,v,l,m,x,y;
memset(&INF,0x7f,sizeof(INF));
scanf("%d",&n);
for (i=; i<=n-; ++i)
{
scanf("%d%d",&u,&v);
add(u,v);
add(v,u);
}
for (int i=; i<=n; ++i)
scanf("%d",&a[i]);
Depth[]=;
dfs1();
dfs2(,);//两边预处理
Build(,,n,TREE);//TREE数组保存用来建线段树的区间
scanf("%d",&m);
for (int i=; i<=m; ++i)
{
scanf("%s%d%d",&st,&x,&y);
if (st[]=='H')
Update(,,n,T_NUM[x],y);
if (st[]=='M')
printf("%d\n",GetMax(x,y));
if (st[]=='S')
printf("%d\n",GetSum(x,y));
}
}

1036. [ZJOI2008]树的统计【树链剖分】的更多相关文章

  1. BZOJ 1036: [ZJOI2008]树的统计Count-树链剖分(点权)(单点更新、路径节点最值、路径求和)模板,超级认真写了注释啊啊啊

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

  2. 树的统计Count---树链剖分

    NEFU专项训练十和十一——树链剖分 Description 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t ...

  3. BZOJ 1036 树的统计-树链剖分

    [ZJOI2008]树的统计Count Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 12904 Solved: 5191[Submit][Status ...

  4. [ZJOI2008]树的统计——树链剖分

    本题是一个树链剖分裸题,由于比较菜,老是RE,后来发现是因为使用了全局变量. /************************************************************ ...

  5. BZOJ1036[ZJOI2008]树的统计——树链剖分+线段树

    题目描述 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t : 把结点u的权值改为t II. QMAX u v ...

  6. [luogu P2590 ZJOI2008] 树的统计 (树链剖分)

    题目描述 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w. 我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t : 把结点u的权值改为t II. QMAX u ...

  7. luoguP2590 [ZJOI2008]树的统计(树链剖分)

    luogu P2590 [ZJOI2008]树的统计 题目 #include<iostream> #include<cstdlib> #include<cstdio> ...

  8. 洛谷P2590 [ZJOI2008] 树的统计 [树链剖分]

    题目传送门 树的统计 题目描述 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w. 我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t : 把结点u的权值改为t ...

  9. BZOJ-1036 树的统计Count 链剖线段树(模板)=(树链剖分+线段树)

    潇爷昨天刚刚讲完...感觉得还可以...对着模板打了个模板...还是不喜欢用指针.... 1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec Memory Lim ...

  10. bzoj1036 树的统计 树链剖分模板

    题意:给出树上任意两点,求路径上的值的和与最大值,带单点修改操作 树链剖分思路: 1.对树进行dfs求出点的深度和父亲节点,然后求出轻重儿子(重儿子就是点最多的那个子树,其余都是轻儿子),用一个son ...

随机推荐

  1. js 筛选数据

    <input type="text" id="filterName"> <div class="scope fr"> ...

  2. 修改VS类模板自动添加public修饰符和版权注释信息

    在开发过程中,我们经常需要给类或接口添加public修饰符(默认没有)和一些相关的注释信息,这个工作是机械而枯燥的,而这个简单的需求其实是可以通过修改VS自带的类模板来实现的,下面是详细的修改步骤. ...

  3. Unix环境高级编程:守护进程

    参考 Unix环境高级编程,第9,13章 介绍 守护进程就是Linux中使用ps aux那些一般以d结尾的程序,比如rsyslogd,sshd等,为daemon简称.他们是长期在后台执行的随终端关闭而 ...

  4. CSS让DIV按照背景图片的比例缩放,并让背景图片填充整个元素(转)

    目的是:通过background的一系列属性,让DIV按照背景图片的比例缩放,并让背景图片填充整个DIV 首先我们需要让背景图片在指定的DIV中全部填充显示 之前看有用类似 background-at ...

  5. 借助预编译防止sql注入攻击

    可重用的sql操作类 public ResultSet doQuery(String sql,Object[] params){ ResultSet rs = null; conn = this.ge ...

  6. OSGI企业应用开发(十三)OSGI Web应用开发(二)

    上篇文章介绍了OSGI Web应用的两种开发模式,并把Jetty应用服务器以Bundle的形式整合到Equinox容器中,已这种模式开发Web应用,所有的应用程序资源,例如Servlet.JSP.HT ...

  7. 葡萄城报表 SP2 新特性(1)— 单元格智能合并

    中国式复杂报表的布局,因为数据的动态性和结构性,导致其布局往往是无规律,且在设计时无法预测的,如单元格合并,通常不仅希望在每一列的数据展现中,能够根据需要自动将相同的单元格合并,且每个单元格之间该属性 ...

  8. Postman Postman测试接口之JSON结构化数据提交

    Postman测试接口之JSON结构化数据提交   by:授客 QQ:1033553122 本文主要是针对结构比较复杂一点的JSON协议数据的提交做个简单说明 举例: 用户下订单接口 接口方向 客户端 ...

  9. 微信小程序开发--宽为百分百,页面仍可左右滑动

    这段时间小程序开发时,很多时候,希望内容充满整个屏幕(高度.宽度100%),如下图 但是在设置 .followrecords-container{width:100%;} 后发现 手机在横向上虽然页面 ...

  10. View的measure机制

    Android中View框架的工作机制中,主要有三个过程: 1.View树的测量(measure)Android View框架的measure机制     2.View树的布局(layout) And ...