模板题。。。

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
#define N 30001
#define INF 1000000000
inline char Nc(){
static char buf[],*p1=buf,*p2=buf;
if(p1==p2){
p2=(p1=buf)+fread(buf,,,stdin);
if(p1==p2)return EOF;
}
return *p1++;
}
inline void Read(int& x){
char c=Nc(),b=;
for(;c<''||c>'';c=Nc())if(c=='-')b=-;
for(x=;c>=''&&c<='';x=x*+c-,c=Nc());x*=b;
}
inline void Read(char* s){
int i=;
char c=Nc();
while(c!=' ')s[i]=c,i++,c=Nc();
}
int Len;
char s[];
inline void Print(int x){
if(x<){
putchar('-');
x=-x;
}
if(!x){
putchar('');putchar('\n');
return;
}
for(Len=;x;x/=)s[++Len]=x%;
for(;Len;Len--)putchar(s[Len]+);
putchar('\n');
}
struct Edge{
int To,Next;
}e[N<<];
inline int _Max(int x,int y){
return x>y?x:y;
}
int h[N],i,j,k,Num,n,m,T,a[N],w[N],x,y,w2[N],Top[N],Size[N],Son[N],f[N],Sum[N<<],Max[N<<],Deep[N];
char S[];
inline void Add(int x,int y){
e[++Num].To=y;e[Num].Next=h[x];h[x]=Num;
}
void Dfs1(int x,int Fa){
f[x]=Fa;Size[x]=;Deep[x]=Deep[Fa]+;
for(int i=h[x];i;i=e[i].Next)
if(e[i].To!=Fa){
Dfs1(e[i].To,x);
Size[x]+=Size[e[i].To];
if(Size[e[i].To]>Size[Son[x]])Son[x]=e[i].To;
}
}
void Dfs2(int x,int Tmp){
w[x]=++m;w2[m]=x;Top[x]=Tmp;
if(Son[x])Dfs2(Son[x],Tmp);
for(int i=h[x];i;i=e[i].Next)
if(e[i].To!=f[x]&&e[i].To!=Son[x])Dfs2(e[i].To,e[i].To);
}
void Build(int Node,int l,int r){
if(l==r){
Sum[Node]=Max[Node]=a[w2[l]];
return;
}
int Mid=(l+r)>>;
Build(Node<<,l,Mid);
Build(Node<<|,Mid+,r);
Sum[Node]=Sum[Node<<]+Sum[Node<<|];
Max[Node]=_Max(Max[Node<<],Max[Node<<|]);
}
void Update(int Node,int l,int r,int x,int y){
if(l==r){
Sum[Node]=Max[Node]=y;
return;
}
int Mid=(l+r)>>;
if(x<=Mid)Update(Node<<,l,Mid,x,y);else Update(Node<<|,Mid+,r,x,y);
Sum[Node]=Sum[Node<<]+Sum[Node<<|];
Max[Node]=_Max(Max[Node<<],Max[Node<<|]);
}
int Querysum(int Node,int l,int r,int L,int R){
if(l>R||r<L)return ;
if(l>=L&&r<=R)return Sum[Node];
int Mid=(l+r)>>;
return Querysum(Node<<,l,Mid,L,R)+Querysum(Node<<|,Mid+,r,L,R);
}
int Querymax(int Node,int l,int r,int L,int R){
if(l>R||r<L)return -INF;
if(l>=L&&r<=R)return Max[Node];
int Mid=(l+r)>>;
return _Max(Querymax(Node<<,l,Mid,L,R),Querymax(Node<<|,Mid+,r,L,R));
}
int Querysum_tree(int u,int v){
int Ans=;
while(Top[u]!=Top[v])
if(Deep[Top[u]]<Deep[Top[v]]){
Ans+=Querysum(,,m,w[Top[v]],w[v]);
v=f[Top[v]];
}else{
Ans+=Querysum(,,m,w[Top[u]],w[u]);
u=f[Top[u]];
}
if(w[u]<w[v])Ans+=Querysum(,,m,w[u],w[v]);else Ans+=Querysum(,,m,w[v],w[u]);
return Ans;
}
int Querymax_tree(int u,int v){
int Ans=-INF;
while(Top[u]!=Top[v])
if(Deep[Top[u]]<Deep[Top[v]]){
Ans=_Max(Ans,Querymax(,,m,w[Top[v]],w[v]));
v=f[Top[v]];
}else{
Ans=_Max(Ans,Querymax(,,m,w[Top[u]],w[u]));
u=f[Top[u]];
}
if(w[u]<w[v])Ans=_Max(Ans,Querymax(,,m,w[u],w[v]));else Ans=_Max(Ans,Querymax(,,m,w[v],w[u]));
return Ans;
}
int main()
{
Read(n);
for(i=;i<n;i++){
Read(x);Read(y);
Add(x,y);
Add(y,x);
}
for(i=;i<=n;i++)Read(a[i]);
Dfs1(,);
Dfs2(,);
Build(,,m);
Read(T);
while(T--){
Read(S);Read(x);Read(y);
if(S[]=='C')Update(,,m,w[x],y);else
if(S[]=='S')Print(Querysum_tree(x,y));else Print(Querymax_tree(x,y));
}
return ;
}

bzoj1036

bzoj1036--树链剖分的更多相关文章

  1. 洛谷3384&bzoj1036树链剖分

    值得注意的是: 一个点的子树是存在一起的...也就是说我们修改子树的时候只用... /********************************************************* ...

  2. 【BZOJ1036】[ZJOI2008]树的统计Count 树链剖分

    [BZOJ1036][ZJOI2008]树的统计Count Description 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成一些操作: I. ...

  3. 【BZOJ1036】 树的统计Count (树链剖分)

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

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

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1036 题意概括 一个树,每个节点有一个权值.3种操作. 1:修改某一个节点的权值. 2:询问某两个 ...

  5. [BZOJ1036][ZJOI2008]树的统计Count 解题报告|树链剖分

    树链剖分 简单来说就是数据结构在树上的应用.常用的为线段树splay等.(可现在splay还不会敲囧) 重链剖分: 将树上的边分成轻链和重链. 重边为每个节点到它子树最大的儿子的边,其余为轻边. 设( ...

  6. 【BZOJ1036】树的统计Count(树链剖分,LCT)

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

  7. bzoj1036 [ZJOI2008]树的统计Count 树链剖分模板题

    [ZJOI2008]树的统计Count Description 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成 一些操作: I. CHANGE u ...

  8. bzoj1036 [ZJOI2008]树的统计Count(树链剖分)

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

  9. 树链剖分学习&BZOJ1036

    题目传送门 树链剖分,计算机术语,指一种对树进行划分的算法,它先通过轻重边剖分将树分为多条链,保证每个点属于且只属于一条链,然后再通过数据结构(树状数组.SBT.SPLAY.线段树等)来维护每一条链. ...

  10. bzoj1036 count 树链剖分或LCT

    这道题很久以前用树链剖分写的,最近在学LCT ,就用LCT再写了一遍,也有一些收获. 因为这道题点权可以是负数,所以在update时就要注意一下,因为平时我的0节点表示空,它的点权为0,这样可以处理点 ...

随机推荐

  1. MJRefresh 源码解读 + 使用

    MJRefresh这个刷新控件是一款非常好用的框架,我们在使用一个框架的同时,最好能了解下它的实现原理,不管是根据业务要求在原有的基础上修改代码,还是其他的目的,弄明白作者的思路和代码风格,会受益匪浅 ...

  2. 满堂红CIO邓劲翔:房屋中介突围

    人脸识别.客户关系管理进度监控.业务流程实时监控.网站访问人数及流量实时监控等实际企业应用场景淋漓尽致.羽羽如生的以大屏幕上图表形式展现在人们面前,如果你不去继续询问,你不会知道这是一家才刚刚在房地产 ...

  3. PMON failed to acquire latch, see PMON dump

    前几天,一台Oracle数据库(Oracle Database 10g Release 10.2.0.4.0 - 64bit Production)监控出现"PMON failed to a ...

  4. 0042 MySQL学习笔记-入门--01

    基本概念: 数据库DB(database): 数据的仓库,数据的集合,是数据的一种结构化的存储 数据库管理系统DBMS(database management system): 管理数据库的一套软件 ...

  5. OpenSUSE下编译安装OpenFoam

    在不是Ubuntu系统下安装OpenFoam,需要采用编译安装的方式.以下以OpenSuSE为例进行编译安装. 1 软件包准备 需要下载两个程序包: OpenFOAM-4.x-version-4.1. ...

  6. 学习笔记:7z在delphi的应用

    最近做个发邮件的功能,需要将日志文件通过邮件发送回来用于分析,但是日志文件可能会超级大,测算下来一天可能会有800M的大小.所以压缩是不可避免了,delphi中的默认压缩算法整了半天不太好使,就看了看 ...

  7. ASP.NET跨平台最佳实践

    前言 八年的坚持敌不过领导的固执,最终还是不得不阔别已经成为我第二语言的C#,转战Java阵营.有过短暂的失落和迷茫,但技术转型真的没有想象中那么难.回头审视,其实单从语言本身来看,C#确实比Java ...

  8. 如果你发现mysql的外键约束不管用了

    不知为何我机子上的mysql竟然默认关闭外键约束,导致我试了好多遍都可以插入非法值,以下语句可以开启约束 SET foreign_key_checks = 1; (0则关闭) 备忘

  9. 修改Tomcat响应请求时返回的Server内容

    HTTP Server在响应请求时,会返回服务器的Server信息,比如 Tomcat 7 的Header是: 这东西其实会给一些别有用心之人带来一定的提示作用:为安全起见,我们一般会建议去掉或修改这 ...

  10. 自学MVC看这里——全网最全ASP.NET MVC 教程汇总

    MVC架构已深得人心,微软也不甘落后,推出了Asp.net MVC.小编特意整理博客园乃至整个网络最具价值的MVC技术原创文章,为想要学习ASP.NET MVC技术的学习者提供一个整合学习入口.本文从 ...