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..其实就是把树上莫队和带修莫队结合到一起,首先求出括号序,就是进一次出一次那种的,然后如果求两个点 ...
随机推荐
- 【BZOJ】2820: YY的GCD
[题意]给定N, M,求1<=x<=N, 1<=y<=M且gcd(x, y)为质数的(x, y)有多少对.T<=10^4,N,M<=10^7. [算法]数论(莫比乌 ...
- 20155117 王震宇 2006-2007-2 《Java程序设计》第四周学习总结
教材学习内容总结 继承(inheritance) 继承是面向对象软件技术当中的一个概念.继承可以使得子类别具有父类别的各种属性和方法,避免了重复的行为定义.在子类别继承父类别的同时,可以重新定义某些属 ...
- 面试整理(2)跨域:jsonp与CORS
问题:跨域有哪些方法?jsonp的原理是什么? jsonp: 先说jsonp,jsonp的主要原理是利用script标签的src可以跨域请求,据说有src属性的都可以跨域请求,但script标签返回的 ...
- html 中的列表
html 中列表可以分为 1. 无序列表(ul--li 的形式) 2. 有序列表(ol li的形式) 3. 定义列表(dl 的形式) 下面来看几种列表的具体内容: 1.无序列表. 无序列表的格式 ...
- bzoj 2303 并查集
首先如果没有限制的话,我们可以直接求出答案,假设对于n*m的矩阵,我们最上方一行和左方的一列随意确定,那么首先这写确定的状态肯定是不会不合法的,因为我们可以调整剩下的01状态来使得这一行一列的状态合法 ...
- Web攻防系列教程之 Cookie注入攻防实战
摘要:随着网络安全技术的发展,SQL注入作为一种很流行的攻击方式被越来越多的人所知晓.很多网站也都对SQL注入做了防护,许多网站管理员的做法就是添加一个防注入程序.这时我们用常规的手段去探测网站的SQ ...
- ThinkPHP的输出和模型使用
1.假设在v层需要输出一个变量怎么办呢?即如同在html当中输出php代码. 可以直接使用{$name}代替.花括号被称之为标识符.可以通过修改配置项('TMPL_L_DELIM'=>'< ...
- python基础===基于cv2的播放器
import cv2 import threading import win32gui,win32con class Producer(threading.Thread): ""& ...
- React 16 源码瞎几把解读 【三 点 一】 把react组件对象弄到dom中去(矛头指向fiber,fiber不解读这个过程也不知道)
一.ReactDOM.render 都干啥了 我们在写react的时候,最后一步肯定是 ReactDOM.render( <div> <Home name="home&qu ...
- python selenium登陆网易云音乐
from selenium import webdriver import time driver=webdriver.Chrome() driver.get("http://music.1 ...