bzoj3991: [SDOI2015]寻宝游戏--DFS序+LCA+set动态维护
之前貌似在hdu还是poj上写过这道题。
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<set>
#define maxn 100010
#define INF 0x7fffffff
using namespace std;
struct node{
int to,cost,next;
}e[maxn*];
int n,m,u,v,c,logn,tot,time,x;
],head[maxn],dep[maxn],id[maxn],pos[maxn];
];
bool flag[maxn];
long long ans,t;
set<int> st;
inline void insert(int u, int v, int c){
e[++tot].to=v;
e[tot].cost=c;
e[tot].next=head[u];
head[u]=tot;
}
inline void dfs(int u, int f, int d, int c){
pos[u]=++time; id[time]=u;
dep[u]=d;
fa[u][]=f; dis[u][]=c;
; i<=logn; i++) fa[u][i]=fa[fa[u][i-]][i-];
; i<=logn; i++) dis[u][i]=dis[u][i-]+dis[fa[u][i-]][i-];
; i=e[i].next)
,e[i].cost);
}
inline long long lca(int u, int v){
;
if (dep[u]>dep[v]) swap(u,v);
while (dep[u]<dep[v]){
; i--)
if (dep[u]<dep[fa[v][i]]){
sum+=dis[v][i];
v=fa[v][i];
}
sum+=dis[v][];
v=fa[v][];
}
if (u==v) return sum;
; i--)
if (fa[u][i]!=fa[v][i]){
sum+=dis[u][i]+dis[v][i];
u=fa[u][i]; v=fa[v][i];
}
sum+=dis[u][]+dis[v][];
return sum;
}
int main(){
scanf("%d%d", &n, &m);
logn=; <<logn)<n) logn++;
tot=-; memset(head,-,sizeof(head));
; i<n; i++){
scanf("%d%d%d", &u, &v, &c);
insert(u,v,c);
insert(v,u,c);
}
time=;
dfs(,,,);
st.insert(-INF); st.insert(INF);
while (m--){
scanf("%d", &x);
if (!flag[x]){
flag[x]=;
int l=*--st.lower_bound(pos[x]), r=*st.upper_bound(pos[x]);
st.insert(pos[x]);
if (l !=-INF) ans+=lca(id[l],x);
if (r != INF) ans+=lca(x,id[r]);
if (l!=-INF && r!=INF) ans-=lca(id[l],id[r]);
}
else{
flag[x]=;
st.erase(pos[x]);
int l=*--st.lower_bound(pos[x]), r=*st.upper_bound(pos[x]);
if (l!=-INF) ans-=lca(id[l],x);
if (r!= INF) ans-=lca(x,id[r]);
if (l!=-INF && r!=INF) ans+=lca(id[l],id[r]);
}
){
int l=*++st.lower_bound(-INF), r=*--st.lower_bound(INF);
t=lca(id[l],id[r]);
}
printf("%lld\n", ans+t);
}
;
}
bzoj3991: [SDOI2015]寻宝游戏--DFS序+LCA+set动态维护的更多相关文章
- [BZOJ 3991][SDOI2015]寻宝游戏(dfs序)
题面 小B最近正在玩一个寻宝游戏,这个游戏的地图中有N个村庄和N-1条道路,并且任何两个村庄之间有且仅有一条路径可达.游戏开始时,玩家可以任意选择一个村庄,瞬间转移到这个村庄,然后可以任意在地图的道路 ...
- [BZOJ3991][SDOI2015]寻宝游戏
[BZOJ3991][SDOI2015]寻宝游戏 试题描述 小B最近正在玩一个寻宝游戏,这个游戏的地图中有N个村庄和N-1条道路,并且任何两个村庄之间有且仅有一条路径可达.游戏开始时,玩家可以任意选择 ...
- CH#56C 异象石 和 BZOJ3991 [SDOI2015]寻宝游戏
异象石 CH Round #56 - 国庆节欢乐赛 描述 Adera是Microsoft应用商店中的一款解谜游戏. 异象石是进入Adera中异时空的引导物,在Adera的异时空中有一张地图.这张地图上 ...
- BZOJ3991 [SDOI2015]寻宝游戏 【dfs序 + lca + STL】
题目 小B最近正在玩一个寻宝游戏,这个游戏的地图中有N个村庄和N-1条道路,并且任何两个村庄之间有且仅有一条路径可达.游戏开始时,玩家可以任意选择一个村庄,瞬间转移到这个村庄,然后可以任意在地图的道路 ...
- luogu3320 寻宝游戏 (dfs序+倍增lca+set)
一定是从随便某个点开始,然后按着dfs序的顺序跑一圈是最好的 所以说,新加一个点x,就减少了dis(pre,next),增加了dis(pre,x),dis(x,nxt) 删掉一个点同理 这个可以用se ...
- [bzoj3991][SDOI2015]寻宝游戏_树链的并_倍增lca_平衡树set
寻宝游戏 bzoj-3991 SDOI-2015 题目大意:题目链接. 注释:略. 想法:我们发现如果给定了一些点有宝物的话那么答案就是树链的并. 树链的并的求法就是把所有点按照$dfs$序排序然后相 ...
- bzoj3991 [Sdoi2015]寻宝游戏 set动态维护虚树+树链求并
题目大意:支持多次操作,增加或删除一个关键点 动态维护虚树边权和*2 分析:可以用树链求并的方法,最后减去虚树的根到1距离 注意到树链求并是所有点到根距离-所有dfn序相邻两点的LCA到根距离 找df ...
- bzoj3991 [SDOI2015]寻宝游戏 树链的并
题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=3991 题解 貌似这个东西叫做树链的并,以前貌似写过一个类似的用来动态维护虚树. 大概就是最终的 ...
- 【dfs序】【set】bzoj3991 [Sdoi2015]寻宝游戏
在考试代码的基础上稍微改改就a了……当时为什么不稍微多想想…… 插入/删除一个新节点时就把其dfn插入set/从set中删除. 当前的答案就是dfn上相邻的两两节点的距离和,再加上首尾节点的距离. 比 ...
随机推荐
- Struts2请求参数校验
校验的分类 客户端数据校验 和 服务器端数据校验 客户端数据校验 ,通过JavaScript 完成校验 (改善用户体验,使用户减少出错 ) 服务器数据校验 ,通过Java代码 完成校验 struts2 ...
- JAVA Day4
循 环 所有循环的流程 声明循环变量-->判断循环条件-->执行循环操作-->更新循环变量 不断执2 ...
- Spring事务解析2-标签解析
根据自定义标签的使用规则,可以知道会执行AnnotationDrivenBeanDefinitionParser的parse @Override public BeanDefinition parse ...
- 通俗理解T检验与F检验的区别【转】
转自:http://blog.sina.com.cn/s/blog_4ee13c2c01016div.html1,T检验和F检验的由来一般而言,为了确定从样本(sample)统计结果推论至总体时所犯错 ...
- 浩瀚科技PDA移动开单|盘点机 数据采集器 条码扫描开单微POS软件 现场打印开单
PDA移动开单,是我公司的一款便携式开单配套产品,PDA能通过蓝牙.无线局域网.互联网直接与主机连接,让公司业务人员能随时随地了解公司产品信息并且进行开单.入库.库存.盘点等一系列进销存操作.是现今企 ...
- BestCoder Round #71 (div.2)
数学 1001 KK's Steel 类似斐波那契求和 #include <cstdio> #include <cstring> #include <algorithm& ...
- Jenkins启动时报错:java.net.BindException: Address already in use: bind 解决方法
下载jenkins.war包后,进入Jenkins.war包目录下,运行java -jar jenkins.war时报端口被占用的错误:java.net.BindException: Address ...
- Intellij IDEA常用快捷键——Mac版
http://blog.csdn.net/longshen747/article/details/17204699 http://totohust.iteye.com/blog/1035550 设置自 ...
- iOS之03-类的合理设计
以下代码为了充分学习理解 类与对象 类与对象的定义 类就是将事物的共有属性和方法抽离出来形成的:类是现实世界或思维世界中的实体在计算机中的反映,它将数据以及这些数据上的操作封装在一起. 对象是具有类类 ...
- python 代码片段21
#coding=utf-8 @doco def foo(): pass ''' deco把foo函数拿过来,加上一些额外的功能再重新赋值给foo,如下 ''' foo=deco(foo) def lo ...