异象石(就是sdio宝藏那题)
题解:
之前这道题写过两次题解了吧。。
实现的时候可以用set<int,cmp>来实现按照dfn排序
代码:
感觉别人的分类讨论比我的简单。。
但我觉得我这个写起来也不烦就不看别人的了。。
看了一下 发现他们是把一个的前驱后继处理为自己 于是就避免了分类讨论(我xxx)
linux复制出来行间距变成两倍了。。
#include <bits/stdc++.h> using namespace std; #define rll ll #define IL inline #define rep(i,h,t) for (rll i=h;i<=t;i++) #define dep(i,t,h) for (rll i=t;i>=h;i--) #define ll long long const ll N=4e5; struct re{ ll a,b,c; }e[N*]; ll cnt,head[N],l; ll bz[][N]; ll sum[N]; void arr(ll x,ll y,ll z) { e[++l].a=head[x]; e[l].b=y; e[l].c=z; head[x]=l; } ll dfn[N],dep[N]; void dfs(ll x,ll y) { dfn[x]=++cnt; dep[x]=dep[y]+; bz[][x]=y; for (rll u=head[x];u;u=e[u].a) { rll v=e[u].b; if (v!=y) { sum[v]=sum[x]+e[u].c; dfs(v,x); } } } ll lca(ll x,ll y) { if (dep[x]<dep[y]) swap(x,y); dep(i,,) if (dep[bz[i][x]]>=dep[y]) x=bz[i][x]; if (x==y) return x; dep(i,,) if (bz[i][x]!=bz[i][y]) x=bz[i][x],y=bz[i][y]; return bz[][x]; } struct cmp{ bool operator () (ll x,ll y) { return dfn[x]<dfn[y]; } }; #define tp set<ll,cmp>::iterator set<ll,cmp> S; tp it,it2,it3; IL tp pre(tp it) { tp it2=it; it2--; return(it2); } IL tp nxt(tp it) { tp it2=it; it2++; return(it2); } int main() { freopen("1.in","r",stdin); freopen("1.out","w",stdout); ios::sync_with_stdio(false); ll n; cin>>n; rep(i,,n-) { ll x,y,z; cin>>x>>y>>z; arr(x,y,z); arr(y,x,z); } dfs(,); rep(i,,) rep(j,,n) bz[i][j]=bz[i-][bz[i-][j]]; ll m; cin>>m; ll ans=; ll num=; rep(i,,m) { char cc; ll x; cin>>cc; if (cc=='+') { cin>>x; num++; ans+=*sum[x]; it =S.insert(x).first; if (num==) continue; bool tt=; if (it==S.begin()) { tt=; it2=nxt(it); it3=S.end(); it3--; if (num!=) { ans+=*sum[lca(*it2,*it3)]; ans-=*sum[lca(x,*it2)]; ans-=*sum[lca(x,*it3)]; } else ans-=*sum[lca(x,*it2)]; } it2=nxt(it); if (!tt&&it2==S.end()) { tt=; it2=pre(it); it3=S.begin(); if (num!=) { ans+=*sum[lca(*it2,*it3)]; ans-=*sum[lca(x,*it2)]; ans-=*sum[lca(x,*it3)]; } else ans-=*sum[lca(x,*it2)]; } if (!tt) { it2=pre(it); it3=nxt(it); ans+=*sum[lca(*it2,*it3)]; ans-=*sum[lca(x,*it2)]; ans-=*sum[lca(x,*it3)]; } } if (cc=='-') { cin>>x; num--; if (!num) { ans=; S.clear(); continue; } it=S.find(x); ans-=*sum[x]; bool tt=; if (it==S.begin()) { tt=; it2=nxt(it); it3=S.end(); it3--; if (num>=) { ans-=*sum[lca(*it2,*it3)]; ans+=*sum[lca(x,*it2)]; ans+=*sum[lca(x,*it3)]; } else ans+=*sum[lca(x,*it3)]; } it2=nxt(it); if (!tt&&it2==S.end()) { tt=; it2=pre(it); it3=S.begin(); if (num>=) { ans-=*sum[lca(*it2,*it3)]; ans+=*sum[lca(x,*it2)]; ans+=*sum[lca(x,*it3)]; } else ans+=*sum[lca(x,*it3)]; } if (!tt) { it2=pre(it); it3=nxt(it); ans-=*sum[lca(*it2,*it3)]; ans+=*sum[lca(x,*it2)]; ans+=*sum[lca(x,*it3)]; } S.erase(x); } if (cc=='?') { if (num<=) cout<<<<endl; else cout<<ans/<<endl; } } return ; }
异象石(就是sdio宝藏那题)的更多相关文章
- CH#56C 异象石 和 BZOJ3991 [SDOI2015]寻宝游戏
异象石 CH Round #56 - 国庆节欢乐赛 描述 Adera是Microsoft应用商店中的一款解谜游戏. 异象石是进入Adera中异时空的引导物,在Adera的异时空中有一张地图.这张地图上 ...
- [bzoj1912]异象石(set)
Description Adera是Microsoft应用商店中的一款解谜游戏. 异象石是进入Adera中异时空的引导物,在Adera的异时空中有一张地图.这张地图上有N个点,有N-1条双向边把它们连 ...
- Luogu P3320 [SDOI2015]寻宝游戏 / 异象石 【LCA/set】
期末考试结束祭! 在期末考试前最后一发的测试中,异象石作为第二道题目出现QAQ.虽然知道是LCA图论,但还是敲不出来QAQ. 花了两天竞赛课的时间搞懂(逃 异象石(stone.pas/c/cpp)题目 ...
- [LOJ#10132]异象石
Description Adera 是 Microsoft 应用商店中的一款解谜游戏. 异象石是进入 Adera 中异时空的引导物,在 Adera 的异时空中有一张地图.这张地图上 有 N 个点,有 ...
- CH#56C 异象石
一道LCA 原题链接 先跑一边\(dfs\),求出每个节点的时间戳,如果我们将有异象石的节点按时间戳从小到大的顺序排列,累加相邻两节点之间的距离(首尾相邻),会发现总和就是答案的两倍. 于是我们只需要 ...
- 蓝皮书:异象石 【dfs序+lca】
题目详见蓝皮书[算法竞赛:进阶指南]. 题目大意: 就是给你一颗树,然后我们要在上面进行三种操作: 1.标记某个点 或者 2.撤销某个点的标记 以及 3.询问标记点在树上连通所需的最短总边 ...
- LOJ #10132. 「一本通 4.4 例 3」异象石
题目地址 LOJ 题解 神仙思路.思路参考自<算法竞赛进阶指南>. 考虑维护dfs序中相邻两个石头的距离,那么每次?的答案就是sum/2(首尾算相邻) 然后维护一下拿个平衡树/set维护一 ...
- lca:异象石(set+dfs序)
题目:https://loj.ac/problem/10132 #include<bits/stdc++.h> using namespace std; ,N,k=,head[]; str ...
- 洛谷P2447 [SDOI2010]外星千足虫(异或方程组)
题意 题目链接 Sol 异或高斯消元的板子题. bitset优化一下,复杂度\(O(\frac{nm}{32})\) 找最优解可以考虑高斯消元的过程,因为异或的特殊性质,每次向下找的时候找到第一个1然 ...
随机推荐
- boost 实现http断点续传
// testc.cpp : Defines the entry point for the console application. // #include "stdafx.h" ...
- vc++高级班之多线程篇[6]---线程间的同步机制①
①.线程同步的必要性: int g_Num = 0; UINT __cdecl ThreadProc(LPVOID lpParameter) { for (int idx = 0; idx &l ...
- TX2 开发套件串口
TX2的底板上有三个串口,位于J21的ttyTHS1,位于J17的ttyTHS2和给蓝牙使用的ttyTHS3. ttyTHS1是控制台串口(serial console),再启动的时候会通过它打印一系 ...
- 我理解的vue生命周期
说些题外话,引出vue的生命周期. 比如人出生到寿终正寝,这是人的一个生命周期.他会经历出生,婴儿时期,童年时期,少年时期,青年,中年,老年,到 end.然后,每个时期都会有一定的历史任务在等着去完成 ...
- linux备忘簿
1.ubuntu中按ctrl+s锁定屏幕,按ctrl+q解锁. 2.vim中撤销和恢复为u和ctlr+r 3.静态库和动态库编译命令: (1)得到hello.o g++ -c hello.cpp (2 ...
- Select2日常操作集合
1.获得多选值 var arraySelected = $('#carTypes').select2("data"); var carTypesDesc = ''; for (va ...
- 基于数组的循环队列(C++模板实现)
循环队列使用数组实现的话,简单.方便.之前实现的队列,当尾端索引到达队列最后的时候,无论前面是否还有空间,都不能再添加数据了.循环队列使得队列的存储单元可以循环利用,它需要一个额外的存储单元来判断队列 ...
- Linux系统基础优化及常用命令
Linux基础系统优化 引言没有,只有一张图. Linux的网络功能相当强悍,一时之间我们无法了解所有的网络命令,在配置服务器基础环境时,先了解下网络参数设定命令. ifconfig 查询.设置网卡和 ...
- 响应式页面-@media介绍
01 响应式页面-@media介绍, 我们为什么要写自适应的页面(响应式页面) 众所周知,电脑.平板.手机的屏幕是差距很大的,假如在电脑上写好了一个页面,在电脑上看起来不错,但是如果放到手机上的话 ...
- Js操作Array数组
之前写过一篇文章,但是很模糊,不过却给我提供了一个思路,所以没有删除,这次写的是一个完善版本! 因为在很多的时候我们在选中了几行数据,然后存放在Array中,如下图: 看下控制台的数据 我双击了这两个 ...