1 #include<stdio.h>
2 #include<algorithm>
3 #include<cstring>
4 #define ll long long
5 #define MAXN 1000005
6 using namespace std;
7
8 char *p1,*p2,buf[1<<20];
9 #define GC (p1==p2&&(p2=(p1=buf)+fread(buf,1,1000000,stdin),p1==p2)?0:*p1++)
10 inline int _R(){
11 char s=GC;int v=0;
12 while(s>57||s<48)s=GC;
13 for(;s>47&&s<58;s=GC)v=v*10+s-48;
14 return v;
15 }
16
17 int N,M,Q,w[MAXN];
18 int en[MAXN],nex[MAXN],las[MAXN],etot;
19 int dep[MAXN],fa[MAXN],In[MAXN],Out[MAXN],vt,E[MAXN],pos[MAXN];
20 int Log[MAXN],RMQ[20][MAXN];
21 ll C[MAXN];
22
23 struct node{
24 bool can;
25 int u,v,lca;
26 }T[MAXN<<2];int m;
27
28 ll getsum(int x){
29 int i;ll ret=0;
30 for(i=x;i;i^=(i&-i))ret+=C[i];
31 return ret;
32 }
33
34 void modify(int x,ll d){
35 for(int i=x;i<=N;i+=(i&-i))C[i]+=d;
36 }
37
38 void link(int x,int y){
39 en[++etot]=y;nex[etot]=las[x];las[x]=etot;
40 en[++etot]=x;nex[etot]=las[y];las[y]=etot;
41 }
42
43 void dfs(int x,int pre){
44 int i,y;
45 dep[x]=dep[pre]+1;
46 In[x]=++vt;
47 fa[x]=pre;
48 E[++E[0]]=x;pos[x]=E[0];
49 for(i=las[x];i;i=nex[i]){
50 y=en[i];if(y==pre)continue;
51 dfs(y,x);
52 E[++E[0]]=x;
53 }
54 Out[x]=vt;
55 }
56
57 int Min(int a,int b){
58 return dep[a]<dep[b]?a:b;
59 }
60
61 int LCA(int x,int y){
62 if(pos[x]>pos[y])swap(x,y);
63 int d=pos[y]-pos[x]+1;
64 return Min(RMQ[Log[d]][pos[x]],RMQ[Log[d]][pos[y]-(1<<Log[d])+1]);
65 }
66
67 int dis(int x,int y){return dep[x]+dep[y]-(dep[LCA(x,y)]<<1);}
68
69 bool cmp(int a,int b){return dep[a]<dep[b];}
70
71 node update(node a,node b){
72 node ret;
73 int tmp[4],x,y;
74 if(!a.can||!b.can){ret.can=false;return ret;}
75 if(dep[a.lca]<dep[b.lca])swap(a,b);
76
77 if(dis(b.u,a.lca)+dis(b.v,a.lca)!=dis(b.u,b.v)){ret.can=false;return ret;}
78 ret.can=true;
79
80 tmp[0]=LCA(a.u,b.u);
81 tmp[1]=LCA(a.v,b.u);
82 tmp[2]=LCA(a.u,b.v);
83 tmp[3]=LCA(a.v,b.v);
84 sort(tmp,tmp+4,cmp);
85 ret.u=tmp[3];ret.v=tmp[2];ret.lca=LCA(ret.u,ret.v);
86
87 return ret;
88 }
89
90 node query(int l,int r){
91 bool flag=false;node ret;
92 for(l+=m-1,r+=m+1;l^r^1;l>>=1,r>>=1){
93 if(~l&1)ret=flag?update(ret,T[l^1]):(flag=true,T[l^1]);
94 if(r&1)ret=flag?update(ret,T[r^1]):(flag=true,T[r^1]);
95 }
96 return ret;
97 }
98
99 void init(){
100 int i,j,n;
101 dfs(1,0);
102 for(i=2;i<=2*N;i++)Log[i]=Log[i>>1]+1;
103 n=E[0];
104 for(i=1;i<=n;i++)RMQ[0][i]=E[i];
105 for(j=1;j<20;j++)
106 for(i=1;i+(1<<j-1)<=n;i++)RMQ[j][i]=Min(RMQ[j-1][i],RMQ[j-1][i+(1<<j-1)]);
107 }
108
109 int main(){
110 int i,op,x,y,v,l,r;
111
112 N=_R();
113 for(i=1;i<N;i++){
114 x=_R();y=_R();
115 link(x,y);
116 }
117
118 init();
119
120 for(i=1;i<=N;i++)w[i]=_R(),modify(In[i],w[i]),modify(Out[i]+1,-w[i]);
121 M=_R();
122 m=1;while(m<=M)m<<=1;
123 for(i=m;i<=(m<<1);i++)T[i].can=false;
124 for(i=1;i<=M;i++){
125 x=_R();y=_R();
126 T[m+i]=(node){true,x,y,LCA(x,y)};
127 }
128 for(i=m-1;i;i--)T[i]=update(T[i<<1],T[i<<1|1]);
129
130 Q=_R();
131 while(Q--){
132 op=_R();
133 if(op==1){
134 x=_R(),v=_R();
135 int d=v-w[x];
136 modify(In[x],d);
137 modify(Out[x]+1,-d);
138 w[x]=v;
139 }
140 else {
141 l=_R(),r=_R();
142 node ret=query(l,r);
143 if(!ret.can)puts("0");
144 else printf("%lld
",getsum(In[ret.u])+getsum(In[ret.v])-(getsum(In[fa[ret.lca]])<<1)-w[ret.lca]);
145 }
146 }
147 }