uoj #58 【WC2013】糖果公园
题面:http://uoj.ac/problem/58
正解:树上带修改莫队。
首先Orz vfk大神,树上莫队的套路还是很厉害的。。http://vfleaking.blog.163.com/blog/static/174807634201311011201627/
我们考虑普通的树上莫队。我们要先把树分好块,分块的方式和王室联邦是一样的,即限定块的大小来分块。当我们限定了块的大小以后,我们能保证块的直径不超过块的大小,于是在同一个块内移动是可以保证复杂度的。然后树上莫队每次就是上一个询问的$u$到这一个询问的$u$的路径修改一遍,$v$也是一样,注意每次询问$LCA$都是要特判的。加入修改操作以后,我们考虑普通莫队算法,就是把块的大小改成$O(n^{\frac{2}{3}})$,然后能够保证总复杂度是$O(n^{\frac{5}{3}})$的,每次询问记录它之前要执行的修改次数。然后我们就可以直接暴力搞了,如果修改多了就撤回,少了就加上。这样我们就能完美地解决这道题了。
//It is made my wfj_2048~
#include <algorithm>
#include <iostream>
#include <complex>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#include <cmath>
#define inf (1<<30)
#define N (100010)
#define il inline
#define RG register
#define ll long long
#define File(s) freopen(s".in","r",stdin),freopen(s".out","w",stdout) using namespace std; struct node1{ int u,v,t,i; }q1[N];
struct node2{ int x,v,pre; }q2[N];
struct edge{ int nt,to; }g[*N]; int head[N],v[N],w[N],top[N],fa[N],son[N],bl[N],sz[N],dep[N],dfn[N],pre[N],col[N],c[N],st[N],vis[N],n,m,Q,tp,Lca,num,cnt,ccnt,cnt1,cnt2,block;
ll ans[N],Ans; il int gi(){
RG int x=,q=; RG char ch=getchar();
while((ch<'' || ch>'') && ch!='-') ch=getchar();
if (ch=='-') q=-,ch=getchar();
while (ch>='' && ch<='') x=x*+ch-,ch=getchar();
return q*x;
} il void insert(RG int from,RG int to){ g[++num]=(edge){head[from],to},head[from]=num; return; } int cmpt(const node1 &a,const node1 &b){
if (bl[a.u]==bl[b.u] && bl[a.v]==bl[b.v]) return a.t<b.t;
if (bl[a.u]==bl[b.u]) return bl[a.v]<bl[b.v]; return bl[a.u]<bl[b.u];
} il void dfs1(RG int x,RG int p){
fa[x]=p,sz[x]=,dep[x]=dep[p]+; RG int v;
for (RG int i=head[x];i;i=g[i].nt){
v=g[i].to; if (v==p) continue;
dfs1(v,x); sz[x]+=sz[v];
if (sz[son[x]]<=sz[v]) son[x]=v;
}
return;
} il void dfs2(RG int x,RG int p,RG int anc){
top[x]=anc,dfn[x]=++cnt; RG int ttp=tp;
if (son[x]) dfs2(son[x],x,anc); RG int v;
if (tp-ttp>=block){ ccnt++; while (tp>ttp) bl[st[tp--]]=ccnt; } //按大小分块
for (RG int i=head[x];i;i=g[i].nt){
v=g[i].to; if (v==p || v==son[x]) continue; dfs2(v,x,v);
if (tp-ttp>=block){ ccnt++; while (tp>ttp) bl[st[tp--]]=ccnt; }
}
st[++tp]=x; return;
} il int lca(RG int u,RG int v){
while (top[u]!=top[v]){
if (dep[top[u]]<dep[top[v]]) swap(u,v);
u=fa[top[u]];
}
return dep[u]<dep[v] ? u : v;
} il void update(RG int x){
if (!vis[x]) vis[x]=,c[col[x]]++,Ans+=(ll)w[c[col[x]]]*(ll)v[col[x]];
else vis[x]=,Ans-=(ll)w[c[col[x]]]*(ll)v[col[x]],c[col[x]]--; return;
} il void modify(RG int x,RG int v){ if (!vis[x]) col[x]=v; else update(x),col[x]=v,update(x); return; } il void change(RG int x,RG int y){
while (x!=y){
if (dep[x]<dep[y]) update(y),y=fa[y];
else update(x),x=fa[x];
}
return;
} il void work(){
n=gi(),m=gi(),Q=gi(),block=pow(n,0.6); RG int type,x,y;
for (RG int i=;i<=m;++i) v[i]=gi();
for (RG int i=;i<=n;++i) w[i]=gi();
for (RG int i=;i<n;++i) x=gi(),y=gi(),insert(x,y),insert(y,x);
while (tp) st[tp--]=ccnt;
for (RG int i=;i<=n;++i) col[i]=gi(),pre[i]=col[i]; dfs1(,),dfs2(,,);
for (RG int i=;i<=Q;++i){
type=gi(),x=gi(),y=gi();
if (type){
if (dfn[x]>dfn[y]) swap(x,y);
q1[++cnt1].u=x,q1[cnt1].v=y,q1[cnt1].t=cnt2,q1[cnt1].i=cnt1;
}
if (!type) q2[++cnt2].x=x,q2[cnt2].v=y,q2[cnt2].pre=pre[x],pre[x]=y;
}
sort(q1+,q1+cnt1+,cmpt); cnt2=q1[].t;
for (RG int i=;i<=cnt2;++i) modify(q2[i].x,q2[i].v);
change(q1[].u,q1[].v),Lca=lca(q1[].u,q1[].v);
update(Lca),ans[q1[].i]=Ans,update(Lca); //LCA特判
for (RG int i=;i<=cnt1;++i){
while (cnt2<q1[i].t) cnt2++,modify(q2[cnt2].x,q2[cnt2].v);
while (cnt2>q1[i].t) modify(q2[cnt2].x,q2[cnt2].pre),cnt2--;
change(q1[i-].u,q1[i].u),change(q1[i-].v,q1[i].v);
Lca=lca(q1[i].u,q1[i].v),update(Lca),ans[q1[i].i]=Ans,update(Lca);
}
for (RG int i=;i<=cnt1;++i) printf("%I64d\n",ans[i]); return; //这几天用windows。。
} int main(){
File("park");
work();
return ;
}
uoj #58 【WC2013】糖果公园的更多相关文章
- [BZOJ3052][UOJ#58][WC2013]糖果公园
[BZOJ3052][UOJ#58][WC2013]糖果公园 试题描述 Candyland 有一座糖果公园,公园里不仅有美丽的风景.好玩的游乐项目,还有许多免费糖果的发放点,这引来了许多贪吃的小朋友来 ...
- BZOJ3052/UOJ#58 [wc2013]糖果公园 莫队 带修莫队 树上莫队
原文链接https://www.cnblogs.com/zhouzhendong/p/BZOJ3052.html 题目传送门 - BZOJ3052 题目传送门 - UOJ#58 题意 给定一棵树,有 ...
- bzoj 3052: [wc2013]糖果公园 带修改莫队
3052: [wc2013]糖果公园 Time Limit: 250 Sec Memory Limit: 512 MBSubmit: 506 Solved: 189[Submit][Status] ...
- 洛谷 P4074 [WC2013]糖果公园 解题报告
P4074 [WC2013]糖果公园 糖果公园 树上待修莫队 注意一个思想,dfn序处理链的方法,必须可以根据类似异或的东西,然后根据lca分两种情况讨论 注意细节 Code: #include &l ...
- AC日记——[WC2013]糖果公园 cogs 1817
[WC2013]糖果公园 思路: 带修改树上莫队(模板): 来,上代码: #include <cmath> #include <cstdio> #include <cst ...
- COGS1817. [WC2013]糖果公园
1817. [WC2013]糖果公园 ★★★☆ 输入文件:park.in 输出文件:park.out 简单对比时间限制:8 s 内存限制:512 MB [题目描述] Candyland ...
- 【BZOJ3052】[wc2013]糖果公园 带修改的树上莫队
[BZOJ3052][wc2013]糖果公园 Description Input Output Sample Input Sample Input Sample Output 84 131 27 84 ...
- 【BZOJ】3052: [wc2013]糖果公园 树分块+带修改莫队算法
[题目]#58. [WC2013]糖果公园 [题意]给定n个点的树,m种糖果,每个点有糖果ci.给定n个数wi和m个数vi,第i颗糖果第j次品尝的价值是v(i)*w(j).q次询问一条链上每个点价值的 ...
- 【Luogu P4074】[WC2013]糖果公园(树上带修改莫队)
题目描述 Candyland 有一座糖果公园,公园里不仅有美丽的风景.好玩的游乐项目,还有许多免费糖果的发放点,这引来了许多贪吃的小朋友来糖果公园游玩. 糖果公园的结构十分奇特,它由 \(n\) 个游 ...
- BZOJ.3052.[WC2013]糖果公园(树上莫队 带修改莫队)
题目链接 BZOJ 当然哪都能交(都比在BZOJ交好),比如UOJ #58 //67376kb 27280ms //树上莫队+带修改莫队 模板题 #include <cmath> #inc ...
随机推荐
- Atlas-手淘组件化框架的前世今生和未来的路
今天手淘技术团队宣布正式开源它们的容器框架Atlas,项目地址: https://github.com/alibaba/atlas 同时他们还推出了项目官网,上线了技术文档: http://atlas ...
- 关于easyUI的datebox加失去焦点事件即click、blur等
想实现日期框easyui-datebox手动输入值,手动输入失去焦点判断输入值是否合法 例如<input id="txtDate" type="text" ...
- 关于ORACLE通过file_id与block_id定位数据库对象遇到的问题的一点思考
在ORACLE中,我们可以通过file_id(file#)与block_id(block#)去定位一个数据库对象(object).例如,我们在10046生成的trace文件中file#=4 block ...
- PHP语言开发微信公众平台(订阅号)之开启开发者模式
(1)打开上一篇我们从花生壳官网获得的外网网址就会看到localhost根目录下的文件(这里不再赘述php环境的搭建).注:因为外网网址在能联网时,访问外网网址的任何人都能看到根目录下的所有文件,不仅 ...
- Linux(CentOS6.7) 安装MySql5.7数据库
linux(CentOS6.7) 环境Mysql 5.7.17安装教程分享给大家,供大家参考,具体内容如下: 1系统约定安装文件下载目录:/data/softwareMysql目录安装位置:/usr/ ...
- Button颜色选择器进阶
drawable/button_color.xml <?xml version="1.0" encoding="utf-8"?> <selec ...
- 性能测试平台效率优化的一次经验(python版)
在做性能测试平台的优化过程中,由于启动任务相对其他测试任务比较频繁,而目前30次两个包的交叉对比(30次)测试需要耗时30分钟整,因此打算优先对测试流程做一次优化,将测试时间消耗降低到20分钟. 由于 ...
- Android Things教程:电气基础之直流电路理论
译者注:由于本人水平有限,译文中难免会出现概念模糊.晦涩难懂,如果实在没心思看下去,请发挥你的学习能动性,到原文中自行翻译,感谢!!!点这里,直达英文各种长句的世界. 好了,既然你选择继续往下看,那就 ...
- NMF和SVD在推荐系统中的应用(实战)
本文以NMF和经典SVD为例,讲一讲矩阵分解在推荐系统中的应用. 数据 item\user Ben Tom John Fred item 1 5 5 0 5 item 2 5 0 3 4 item 3 ...
- zabbix_agent-linux下的安装
scp 10.25.133.184:/usr/local/zabbix-2.4.1.tar.gz /usr/local 1.为了安全考虑zabbix只使用普通用户运行,假如你当前用户叫ttlsa,那么 ...