BZOJ3052 [wc2013] 糖果公园 【树上莫队】
树上莫队和普通的序列莫队很像,我们把树进行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] 糖果公园 【树上莫队】的更多相关文章
- 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 ...
- P4074 [WC2013]糖果公园 树上莫队带修改
题目链接 Candyland 有一座糖果公园,公园里不仅有美丽的风景.好玩的游乐项目,还有许多免费糖果的发放点,这引来了许多贪吃的小朋友来糖果公园游玩. 糖果公园的结构十分奇特,它由 nn 个游览点构 ...
- BZOJ.3052.[WC2013]糖果公园(树上莫队 带修改莫队)
题目链接 BZOJ 当然哪都能交(都比在BZOJ交好),比如UOJ #58 //67376kb 27280ms //树上莫队+带修改莫队 模板题 #include <cmath> #inc ...
- BZOJ 3052: [wc2013]糖果公园 | 树上莫队
题目: UOJ也能评测 题解 请看代码 #include<cstdio> #include<algorithm> #include<cstring> #includ ...
- 【WC2013】 糖果公园 - 树上莫队
问题描述 Candyland 有一座糖果公园,公园里不仅有美丽的风景.好玩的游乐项目,还有许多免费糖果的发放点,这引来了许多贪吃的小朋友来糖果公园游玩.糖果公园的结构十分奇特,它由 n 个游览点构成, ...
- 【WC2013】糖果公园 [树上莫队]
题意: 一棵树,修改一个点的颜色,询问两点路径上每种颜色的权值$val[c]$*出现次数的权值$cou[w[c]]$的和 sro VFK 树上莫队 按照王室联邦的方法分块,块的大小直径个数有保证,并不 ...
- 洛谷P4074 [WC2013]糖果公园(莫队)
传送门 总算会树形莫队了…… 上次听说树形莫队是给树分块,实在看不懂.然后用括号序列的方法做总算能弄明白了 先说一下什么是括号序列,就是在$dfs$的时候,进入的时候记录一下,出去的时候也记录一下 拿 ...
- 【BZOJ-3052】糖果公园 树上带修莫队算法
3052: [wc2013]糖果公园 Time Limit: 200 Sec Memory Limit: 512 MBSubmit: 883 Solved: 419[Submit][Status] ...
- LUOGU P4074 [WC2013]糖果公园 (树上带修莫队)
传送门 解题思路 树上带修莫队,搞了两天..终于开O2+卡常大法贴边过了...bzoj上跑了183s..其实就是把树上莫队和带修莫队结合到一起,首先求出括号序,就是进一次出一次那种的,然后如果求两个点 ...
随机推荐
- LintCode 394: First Will Win
LintCode 394: First Will Win 题目描述 有n个硬币排成一条线.两个参赛者轮流从右边依次拿走1或2个硬币,直到没有硬币为止.拿到最后一枚硬币的人获胜. 请判定 第一个玩家 是 ...
- C语言易错点
C语言易错点 1.每个C语言程序中main函数是有且只有一个的. 2.算法可以没有输入,但必须要有输出. 3.在函数中不可以再定义函数. 4.break可用于循环结构和switch语句. 5.brea ...
- 【leetcode 简单】第二题 反转整数
给定一个 32 位有符号整数,将整数中的数字进行反转. 示例 1: 输入: 123 输出: 321 示例 2: 输入: -123 输出: -321 示例 3: 输入: 120 输出: 21 注意: 假 ...
- F - Debate CodeForces - 1070F 思维
题目链接:https://vjudge.net/problem/CodeForces-1070F 具体思路:首先把所有的00放进去,然后对于10 和01 的取两个数目最小值t,排完序后将前t个加起来, ...
- AES,SHA1,DES,RSA,MD5区别
AES:更快,兼容设备,安全级别高: SHA1:公钥后处理回传 DES:本地数据,安全级别低 RSA:非对称加密,有公钥和私钥 MD5:防篡改 相关: 公开密钥加密(英语:public-key cry ...
- python操作上级子文件
. └── folder ├── data │ └── data.txt └── test1 └── test2 └── test.py import os '***获取当前目录***'print o ...
- C/C++——C语言库函数大全
本文转载自:https://blog.csdn.net/yanfan0916/article/details/6450442###; 1. 分类函数: ctype.h int isalpha(int ...
- .htaccess教程:简介、访问控制、验证、目录浏览控制
一..htaccess简介 1.什么是.htaccess .htaccess是一个纯文本文件,里面存放着Apache服务器配置相关的一些指令,它类似于Apache的站点配置文件,如httpd.conf ...
- 转 proc文件
/proc 是一个伪文件系统, 被用作内核数据结构的接口, 而不仅仅是解释说明/dev/kmem. /proc 里的大多数文件都是只读的, 但也可以通过写一些文件来改变内核变量. 下面对整个 /pro ...
- 51Nod 1352 集合计数(扩展欧几里德)
题目链接:https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1352 题目大意: 给出N个固定集合{1,N},{2,N-1} ...