树上莫队和普通的序列莫队很像,我们把树进行dfs,然后存一个长度为2n的括号序列,就是一个点进去当作左括号,出来当作右括号,然后如果访问从u到v路径,我们可以转化成括号序列的区间,记录x进去的时候编号为f[x],出来时为g[x],然后分类讨论一下(f[u]<f[v]),如果u和v的lca不是u,那么就是从g[u]到f[v],否则就是lca的f到另一个点的f,(可以自己试一下,中间过程没有用的点正好就抵消掉了)这里要注意一下,从g[u]到f[v]的时候我们会少掉lca这个点,特殊处理一下即可,然后按照普通莫队排一下序,暴力就行了。 —— by VANE

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=;
int n,m,cnt1,cnt2,tot,clk,f[N],g[N];
vector<int> M[N];
int id[N<<],blg[N<<];
int bin[],pos[N],fa[N][],c[N],d[N];
int v[N],w[N],last[N],u[N];
bool vis[N];
struct node
{
int l,r,t,id;
}a[N],b[N];
ll ans[N],sum;
void dfs(int x)
{
f[x]=++clk;id[clk]=x;
for(int i=;bin[i]<=d[x];++i)
fa[x][i]=fa[fa[x][i-]][i-];
for(int i=;i<M[x].size();++i)
{
int y=M[x][i];
if(y!=fa[x][])
{
fa[y][]=x;
d[y]=d[x]+;
dfs(y);
}
}
g[x]=++clk;
id[clk]=x;
}
int lca(int x,int y)
{
if(d[x]<d[y]) swap(x,y);
int tmp=d[x]-d[y];
for(int i=;bin[i]<=tmp;++i)
if(tmp&bin[i]) x=fa[x][i];
if(x==y) return x;
for(int i=;i>=;--i)
if(fa[x][i]!=fa[y][i])
x=fa[x][i],y=fa[y][i];
return fa[x][];
}
bool cmp(node x,node y)
{
if(blg[x.l]<blg[y.l]) return ;
if(blg[x.l]==blg[y.l]&&blg[x.r]<blg[y.r]) return ;
if(blg[x.l]==blg[y.l]&&blg[x.r]==blg[y.r]) return x.t<y.t;
return ;
}
void modify(int x)
{
if(vis[x]) sum-=1ll*v[c[x]]*w[u[c[x]]--];
else sum+=1ll*v[c[x]]*w[++u[c[x]]];
vis[x]^=;
}
void change(int x,int y)
{
if(vis[x]) {modify(x);c[x]=y;modify(x);}
else c[x]=y;
}
int main()
{
int cas;
scanf("%d%d%d",&n,&m,&cas);
bin[]=;for(int i=;i<=;++i) bin[i]=bin[i-]<<;
for(int i=;i<=m;++i) scanf("%d",v+i);
for(int i=;i<=n;++i) scanf("%d",w+i);
for(int i=;i<n;++i)
{
int l,r;scanf("%d%d",&l,&r);
M[l].push_back(r);
M[r].push_back(l);
}
for(int i=;i<=n;++i)
scanf("%d",c+i),last[i]=c[i];
int sz=pow(n,2.0/);
dfs();
for(int i=;i<=clk;++i) blg[i]=(i-)/sz;
while(cas--)
{
int l,r,t;
scanf("%d%d%d",&t,&l,&r);
if(t)
{
if(f[l]>f[r]) swap(l,r);
a[++cnt1].r=f[r];a[cnt1].t=cnt2;
a[cnt1].id=cnt1;
a[cnt1].l=(lca(l,r)==l)?f[l]:g[l];
}
else
{
b[++cnt2].l=l;b[cnt2].t=last[l];
last[l]=b[cnt2].r=r;
}
}
sort(a+,a++cnt1,cmp);
int l=,r=,t=;
for(int i=;i<=cnt1;++i)
{
for(;t<=a[i].t;++t) change(b[t].l,b[t].r);
for(;t>a[i].t;--t) change(b[t].l,b[t].t);
while(l>a[i].l) modify(id[--l]);
while(l<a[i].l) modify(id[l++]);
while(r>a[i].r) modify(id[r--]);
while(r<a[i].r) modify(id[++r]);
int x=id[l],y=id[r],tmp=lca(x,y);
if(x!=tmp&&y!=tmp) {modify(tmp);ans[a[i].id]=sum;modify(tmp);}
else ans[a[i].id]=sum;
}
for(int i=;i<=cnt1;++i)
printf("%lld\n",ans[i]);
}

BZOJ3052 [wc2013] 糖果公园 【树上莫队】的更多相关文章

  1. BZOJ3052:[WC2013]糖果公园(树上莫队)

    Description Input Output Sample Input 4 3 51 9 27 6 5 12 33 13 41 2 3 21 1 21 4 20 2 11 1 21 4 2 Sam ...

  2. P4074 [WC2013]糖果公园 树上莫队带修改

    题目链接 Candyland 有一座糖果公园,公园里不仅有美丽的风景.好玩的游乐项目,还有许多免费糖果的发放点,这引来了许多贪吃的小朋友来糖果公园游玩. 糖果公园的结构十分奇特,它由 nn 个游览点构 ...

  3. BZOJ.3052.[WC2013]糖果公园(树上莫队 带修改莫队)

    题目链接 BZOJ 当然哪都能交(都比在BZOJ交好),比如UOJ #58 //67376kb 27280ms //树上莫队+带修改莫队 模板题 #include <cmath> #inc ...

  4. BZOJ 3052: [wc2013]糖果公园 | 树上莫队

    题目: UOJ也能评测 题解 请看代码 #include<cstdio> #include<algorithm> #include<cstring> #includ ...

  5. 【WC2013】 糖果公园 - 树上莫队

    问题描述 Candyland 有一座糖果公园,公园里不仅有美丽的风景.好玩的游乐项目,还有许多免费糖果的发放点,这引来了许多贪吃的小朋友来糖果公园游玩.糖果公园的结构十分奇特,它由 n 个游览点构成, ...

  6. 【WC2013】糖果公园 [树上莫队]

    题意: 一棵树,修改一个点的颜色,询问两点路径上每种颜色的权值$val[c]$*出现次数的权值$cou[w[c]]$的和 sro VFK 树上莫队 按照王室联邦的方法分块,块的大小直径个数有保证,并不 ...

  7. 洛谷P4074 [WC2013]糖果公园(莫队)

    传送门 总算会树形莫队了…… 上次听说树形莫队是给树分块,实在看不懂.然后用括号序列的方法做总算能弄明白了 先说一下什么是括号序列,就是在$dfs$的时候,进入的时候记录一下,出去的时候也记录一下 拿 ...

  8. 【BZOJ-3052】糖果公园 树上带修莫队算法

    3052: [wc2013]糖果公园 Time Limit: 200 Sec  Memory Limit: 512 MBSubmit: 883  Solved: 419[Submit][Status] ...

  9. LUOGU P4074 [WC2013]糖果公园 (树上带修莫队)

    传送门 解题思路 树上带修莫队,搞了两天..终于开O2+卡常大法贴边过了...bzoj上跑了183s..其实就是把树上莫队和带修莫队结合到一起,首先求出括号序,就是进一次出一次那种的,然后如果求两个点 ...

随机推荐

  1. 在Unity中实现屏幕空间阴影(1)

    接着上篇文章,我们实现了SSR效果. 其中的在屏幕空间进行光线追踪的方法是通用的.借此我们再实现一种屏幕空间的效果,即屏幕空间阴影. 文中的图片来自Catlike coding http://catl ...

  2. NASA: A Closer View of the Moon(近距离观察月球)

    Posted to Twitter by @Astro_Alex, European Space Agency astronaut Alexander Gerst, this image shows ...

  3. 【swupdate文档 五】从可信的来源更新镜像

    从可信的来源更新镜像 现在越来越重要的是,设备不仅要能安全地进行更新操作, 而且要能够验证发送的图像是否来自一个已知的源, 并且没有嵌入恶意软件. 为了实现这个目标,SWUpdate必须验证传入的镜像 ...

  4. Appium环境搭建说明(包括报错处理)

    Appium环境搭建说明 一.环境配置 前提是windows系统已安装以下软件: 1.jdk 我装的是1.8.0 2.android-sdk 3.python,3.4-3.6 5.Node.js,v8 ...

  5. html中去掉文本框(input type="text")的边框或只显示下边框

    去掉: <input   type="text"   name="textfield"   style="border:0px;"&g ...

  6. windows下phpstrom中xdebug的使用

    https://laravel-china.org/articles/16425/windows-phpstorm-xdebug-breakpoint-debugging

  7. Erasure Coding(纠删码)深入分析 转

    1.前言 Swift升级到2.0大版本后宣称开始支持纠删码,这其实是一个很有意义的特性,主要是能够在一定程度上解决3副本空间浪费太多的问题.因为3副本这一点是swift推广的最大障碍之一,成本的增加吓 ...

  8. golang-goroutine和channel

    goroutine 在go语言中,每一个并发的执行单元叫做一个goroutine 这里说到并发,所以先解释一下并发和并行的概念: 并发:逻辑上具备同时处理多个任务的能力 并行:物理上在同一时刻执行多个 ...

  9. Hadoop(八)Hadoop数据压缩与企业级优化

    一 Hadoop数据压缩 1.1 概述 压缩技术能够有效减少底层存储系统(HDFS)读写字节数.压缩提高了网络带宽和磁盘空间的效率.在Hadood下,尤其是数据规模很大和工作负载密集的情况下,使用数据 ...

  10. yii2联表查询

    我们用实例来说明这一部分 表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer   (id  customer_name) 订单表Order          (id  order_ ...