之前貌似在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动态维护的更多相关文章

  1. [BZOJ 3991][SDOI2015]寻宝游戏(dfs序)

    题面 小B最近正在玩一个寻宝游戏,这个游戏的地图中有N个村庄和N-1条道路,并且任何两个村庄之间有且仅有一条路径可达.游戏开始时,玩家可以任意选择一个村庄,瞬间转移到这个村庄,然后可以任意在地图的道路 ...

  2. [BZOJ3991][SDOI2015]寻宝游戏

    [BZOJ3991][SDOI2015]寻宝游戏 试题描述 小B最近正在玩一个寻宝游戏,这个游戏的地图中有N个村庄和N-1条道路,并且任何两个村庄之间有且仅有一条路径可达.游戏开始时,玩家可以任意选择 ...

  3. CH#56C 异象石 和 BZOJ3991 [SDOI2015]寻宝游戏

    异象石 CH Round #56 - 国庆节欢乐赛 描述 Adera是Microsoft应用商店中的一款解谜游戏. 异象石是进入Adera中异时空的引导物,在Adera的异时空中有一张地图.这张地图上 ...

  4. BZOJ3991 [SDOI2015]寻宝游戏 【dfs序 + lca + STL】

    题目 小B最近正在玩一个寻宝游戏,这个游戏的地图中有N个村庄和N-1条道路,并且任何两个村庄之间有且仅有一条路径可达.游戏开始时,玩家可以任意选择一个村庄,瞬间转移到这个村庄,然后可以任意在地图的道路 ...

  5. luogu3320 寻宝游戏 (dfs序+倍增lca+set)

    一定是从随便某个点开始,然后按着dfs序的顺序跑一圈是最好的 所以说,新加一个点x,就减少了dis(pre,next),增加了dis(pre,x),dis(x,nxt) 删掉一个点同理 这个可以用se ...

  6. [bzoj3991][SDOI2015]寻宝游戏_树链的并_倍增lca_平衡树set

    寻宝游戏 bzoj-3991 SDOI-2015 题目大意:题目链接. 注释:略. 想法:我们发现如果给定了一些点有宝物的话那么答案就是树链的并. 树链的并的求法就是把所有点按照$dfs$序排序然后相 ...

  7. bzoj3991 [Sdoi2015]寻宝游戏 set动态维护虚树+树链求并

    题目大意:支持多次操作,增加或删除一个关键点 动态维护虚树边权和*2 分析:可以用树链求并的方法,最后减去虚树的根到1距离 注意到树链求并是所有点到根距离-所有dfn序相邻两点的LCA到根距离 找df ...

  8. bzoj3991 [SDOI2015]寻宝游戏 树链的并

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=3991 题解 貌似这个东西叫做树链的并,以前貌似写过一个类似的用来动态维护虚树. 大概就是最终的 ...

  9. 【dfs序】【set】bzoj3991 [Sdoi2015]寻宝游戏

    在考试代码的基础上稍微改改就a了……当时为什么不稍微多想想…… 插入/删除一个新节点时就把其dfn插入set/从set中删除. 当前的答案就是dfn上相邻的两两节点的距离和,再加上首尾节点的距离. 比 ...

随机推荐

  1. LVS 三种工作模式原理、以及优缺点比较(转载)

    原文地址:http://9ilinux.com/149.html 一.NAT模式(VS-NAT) 原理:就是把客户端发来的数据包的IP头的目的地址,在负载均衡器上换成其中一台RS的IP地址,并发至此R ...

  2. Linux查看可执行程序所在路径

    首先通过命令获得进程PID:如4285,然后执行下述命令 cd /proc/4285 ls -l 或直接ls -l /proc/4285 其中exe所在行即为可执行文件的全路经.如下图所示:

  3. CentOS安装PHP和mysql

    新生在不会编译的情况下: 1.安装PHP5 yum install php 根据提示输入Y直到安装完成 2.安装PHP组件,使 PHP5 支持 MySQL yum install php-mysql  ...

  4. JS实现有点炫的图片展示效果-图片解体和组合

    经过4个月的努力学习,迎来了进入市场的最后一个学习项目.自己模仿了一个图片展示效果,用在了项目中,感觉挺炫的.在这里分享一下,希望大家喜欢~! bomb-showImg : 在线演示http://ru ...

  5. .Net 连接Oracle 数据库写法

    using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using Sy ...

  6. vs2008/2010安装无法打开数据文件解决方案

    本人在安装VS2008或2010时,在开始的第一个页面(进度条大约加载到75%左右),提示“无法打开数据文件 'C:/Documents and Settings/Administrator/Loca ...

  7. 解决eclipse报PermGen space内存溢出异常的问题

    异常问题如下所示: 1.点击Eclipse->Window->Preferences,如下所示: 2.点击Server->Runtime Environments,选择Apache ...

  8. 在windows环境中用eclipse搭建hadoop开发环境

    1. 整体环境和设置 1.1 hadoo1.0.4集群部署在4台VMWare虚拟机中,这四台虚拟机都是通过NAT模式连接主机 集群中/etc/hosts文件配置 #本机127.0.0.1 localh ...

  9. iOS Xcode behaviors个人常用Debug配置

  10. MFC 定义和调用全局变量的一种方法

    在CTestApp.h中声明一个int x;然后调用的方式如下: CTestApp *app = (CTestApp *)AfxGetApp(); //生成指向应用程序类的指针,Test处改为对应的项 ...