#include <iostream>
#include <cstdio>
#define INF 10000005
using namespace std;
const int N=1e5+10;
struct TREE{
int l,r,v,maxx;
}t[N*4];
int n,q,a[N];
int head[N*2],to[N*2],next[N*2],tot;
int fa[N],siz[N],dfn[N],rank[N],son[N],top[N],dep[N],cnt;
void add(int u,int v)
{
next[++tot]=head[u];
head[u]=tot;
to[tot]=v;
}
void dfs1(int u)
{
siz[u]=1;
for(int i=head[u];i;i=next[i])
{
int v=to[i];
if(v==fa[u]) continue;
dep[v]=dep[u]+1;
fa[v]=u;
dfs1(v);
siz[u]+=siz[v];
if(siz[v]>siz[son[u]]) son[u]=v;
}
}
void dfs2(int u,int tt)
{
top[u]=tt;
dfn[u]=++cnt;
rank[cnt]=u;
if(!son[u]) return ;
dfs2(son[u],tt);
for(int i=head[u];i;i=next[i])
{
int v=to[i];
if(v!=son[u]&&v!=fa[u])
dfs2(v,v);
}
}
void build(int k,int l,int r)
{
t[k].l=l,t[k].r=r;
if(l==r)
{
t[k].v=t[k].maxx=a[rank[l]];
return ;
}
int mid=(l+r)>>1;
build(k<<1,l,mid);
build(k<<1|1,mid+1,r);
t[k].v=t[k<<1].v+t[k<<1|1].v;
t[k].maxx=max(t[k<<1].maxx,t[k<<1|1].maxx);
}
void change(int k,int x,int w)
{
int l=t[k].l,r=t[k].r;
if(r<x||l>x) return ;
if(l==r&&l==x)
{
t[k].v=t[k].maxx=w;
return ;
}
int mid=(l+r)>>1;
if(x<=mid) change(k<<1,x,w);
else change(k<<1|1,x,w);
t[k].v=t[k<<1].v+t[k<<1|1].v;
t[k].maxx=max(t[k<<1].maxx,t[k<<1|1].maxx);
}
int qmax(int k,int x,int y)
{
int l=t[k].l,r=t[k].r;
if(l>=x&&r<=y) return t[k].maxx;
int mid=(l+r)>>1;
int maxx=-INF;
if(x<=mid) maxx=max(maxx,qmax(k<<1,x,y));
if(y>mid) maxx=max(maxx,qmax(k<<1|1,x,y));
return maxx;
}
int qsum(int k,int x,int y)
{
int l=t[k].l,r=t[k].r;
if(l>=r&&r<=y) return t[k].v;
int mid=(l+r)>>1;
int res=0;
if(x<=mid) res+=qsum(k<<1,x,y);
if(y>mid) res+=qsum(k<<1|1,x,y);
return res;
}
int QSUM(int x,int y)
{
int res=0;
while(top[x]!=top[y])
{
if(dep[top[x]]<dep[top[y]]) swap(x,y);
res+=qsum(1,dfn[top[x]],dfn[x]);
x=fa[top[x]];
}
if(dep[x]>dep[y]) swap(x,y);
return res+=qsum(1,dfn[x],dfn[y]);
}
int QMAX(int x,int y)
{
int res=-INF;
while(top[x]!=top[y])
{
if(dep[top[x]]<dep[top[y]]) swap(x,y);
res=max(res,qmax(1,dfn[top[x]],dfn[x]));
x=fa[top[x]];
}
if(dep[x]>dep[y]) swap(x,y);
return res=max(res,qmax(1,dfn[x],dfn[y]));
}
int main()
{
scanf("%d",&n);
int x,y;
for(int i=1;i<n;i++)
{
scanf("%d%d",&x,&y);
add(x,y),add(y,x);
}
for(int i=1;i<=n;i++) scanf("%d",&a[i]);
dfs1(1);
dfs2(1,1);
build(1,1,n);
scanf("%d",&q);
char k[8];
while(q--)
{
cin>>k;
scanf("%d%d",&x,&y);
if(k[0]=='C') change(1,dfn[x],y);
else if(k[1]=='M') printf("%d\n",QMAX(x,y));
else printf("%d\n",QSUM(x,y));
}
return 0;
}
莫明的TLE......