原题链接

前言

搞不懂为什么要写LCT,搞不懂为什么要加强数据。像这道题是用父亲表示法来做的。虽然复杂度不是log,但是现在下面这份代码却是无论从空间,还是代码量,还是时间都是优秀不止一点。 而且这样还能出在noip这样的考试


sol

一个烂大街的套路就是离线搞。这也是这道题的唯一难点。估计大佬们都已经讲透了。

但是为了照顾我这样的不会LCT的蒟蒻,这里有一个更好的办法,那就是直接用fa[]数组来维系这棵树。比如说,要把u,v相连,首先把u向上用fa数组跑,然后一路将fa数组反向。

然后就可以直接赋值fa[u]=v。

但是写的时候还是心虚,所以写的十分小心,应该把常数弄到最小了。代码一定不能写丑

code

#include<bits/stdc++.h>
using namespace std;
const int _=1e6+;
int fa[],g[][],n,m,Q,anss[_/],mm,par[],sign[],cnt;
int rec[];
struct Edge{
int u,v,w;
}e[_],e1[_];
struct MO{
int u,v,k;
}mo[_];
inline char gc(){
static char buf[<<],*p1=buf,*p2=buf;
return (p1==p2)&&(p2=(p1=buf)+fread(buf,,<<,stdin),p1==p2)?EOF:*p1++;
}
template <class T>
inline void read(T&data){
data=;
register char ch=;
while(ch<''||ch>'')ch=gc();
while(ch<=''&&ch>=''){
data=(data<<)+(data<<)+(ch^);
ch=gc();
}
}
template <class R>
inline void write(R data){
if(data>)write(data/);
putchar(''+data%);
}
bool cmp(register Edge a,register Edge b){return a.w<b.w;}
int fi(register int x){return x==par[x]?x:par[x]=fi(par[x]);}
int main(){
read(n),read(m),read(Q);
register int i,u,v,fu,fv,ff,qq,now,LCA,ans,ANS;
for(i=;i<=m;++i){
register Edge & fff=e1[i];
read(fff.u),read(fff.v),read(fff.w);
}
for(i=;i<=Q;++i){
register MO& IOI=mo[i];
read(IOI.k),read(IOI.u),read(IOI.v);
if(IOI.k==)g[IOI.v][IOI.u]=,g[IOI.u][IOI.v]=;
}
for(i=;i<=m;++i){
register int &IOI=g[e1[i].u][e1[i].v];
if(!IOI)e[++mm]=e1[i];
IOI=g[e1[i].v][e1[i].u]=e1[i].w;
}
sort(e+,e+mm+,cmp);
for(i=;i<=n;++i)par[i]=i;
for(i=;i<=mm;++i){
u=e[i].u,v=e[i].v,fu=fi(u),fv=fi(v);
if(fu==fv)continue;
par[fu]=fv,ff=fa[u],qq=u;
while(ff)
swap(fa[ff],qq),swap(ff,qq);
fa[u]=v;
}
for(i=Q;i;--i){
u = mo[i].u,v=mo[i].v,now=u,rec[now]=;
while(now){sign[now]=i,rec[fa[now]]=max(rec[now],g[now][fa[now]]),now=fa[now];}
LCA=v,ans=,ANS=;
while(LCA&&sign[LCA]!=i){ans=max(ans,g[LCA][fa[LCA]]),LCA=fa[LCA];}
ANS=max(ans,rec[LCA]);
if(mo[i].k==){anss[++cnt]=ANS;}
else {
if(ANS<=g[u][v])continue;
if(ans>rec[LCA])swap(u,v);
ff=fa[u],qq=u;
while(g[qq][ff]!=ANS){
swap(fa[ff],qq),swap(ff,qq);
}
fa[u]=v;
} }
for(i=cnt;i;--i)write(anss[i]),puts("");
return ;
}

[WC2006]水管局长的更多相关文章

  1. BZOJ2594: [Wc2006]水管局长数据加强版

    题解: 裸LCT+离线+二分+MST... 代码:(几乎摘抄自hzwer) #include<cstdio> #include<cstdlib> #include<cma ...

  2. bzoj 2594: [Wc2006]水管局长数据加强版 动态树

    2594: [Wc2006]水管局长数据加强版 Time Limit: 25 Sec  Memory Limit: 128 MBSubmit: 934  Solved: 291[Submit][Sta ...

  3. BZOJ 2594: [Wc2006]水管局长数据加强版( LCT )

    离线然后就是维护加边的动态MST, Link cut tree秒掉..不过我写+调了好久...时间复杂度O(NlogN + MlogM) ------------------------------- ...

  4. [bzoj2594][Wc2006]水管局长数据加强版 (lct)

    论蒟蒻的自我修养T_T.. 和noi2014魔法森林基本一样...然而数据范围大得sxbk...UPD:这题如果用lct判联通的话可能会被卡到O(mlogm)..所以最好还是用并查集吧 一开始数组开太 ...

  5. BZOJ 2594: [Wc2006]水管局长数据加强版 [LCT kruskal]

    2594: [Wc2006]水管局长数据加强版 Time Limit: 25 Sec  Memory Limit: 128 MBSubmit: 2917  Solved: 918[Submit][St ...

  6. BZOJ_2594_[Wc2006]水管局长数据加强版_LCT

    BZOJ_2594_[Wc2006]水管局长数据加强版_LCT Description SC省MY市有着庞大的地下水管网络,嘟嘟是MY市的水管局长(就是管水管的啦),嘟嘟作为水管局长的工作就是:每天供 ...

  7. P4172 [WC2006]水管局长(LCT)

    P4172 [WC2006]水管局长 LCT维护最小生成树,边权化点权.类似 P2387 [NOI2014]魔法森林(LCT) 离线存储询问,倒序处理,删边改加边. #include<iostr ...

  8. P4172 [WC2006]水管局长

    P4172 [WC2006]水管局长 前言 luogu数据太小 去bzoj,他的数据大一些 思路 正着删不好维护 那就倒着加,没了 LCT维护他的最小生成树MST 树上加一条边肯定会有一个环 看看环上 ...

  9. [BZOJ2594][WC2006]水管局长加强版(LCT+Kruskal)

    2594: [Wc2006]水管局长数据加强版 Time Limit: 25 Sec  Memory Limit: 128 MBSubmit: 4452  Solved: 1385[Submit][S ...

  10. [BZOJ2594] [WC2006]水管局长(Kruskal+LCT)

    [BZOJ2594] [WC2006]水管局长(Kruskal+LCT) 题面 SC省MY市有着庞大的地下水管网络,嘟嘟是MY市的水管局长(就是管水管的啦),嘟嘟作为水管局长的工作就是:每天供水公司可 ...

随机推荐

  1. Failed to start bean 'stompBrokerRelayMessageHandler'; nested exception is java.lang.NoClassDefFoundError: reactor/io/codec/Codec

    最新版本的Spring需要reactor 2.0,看看你的POM有一个明确的1.1.6依赖. 解决: <dependency> <groupId>org.projectreac ...

  2. systemd的日志管理进程journald

    使用Journalctl查看并操作Systemd日志 systemd拥有强大的处理与系统日志记录功能.在使用其它工具时,日志往往被分散在多套系统当中,由不同的守护进程负责处理. Journal的实现归 ...

  3. 详细介绍Ubuntu 16.04系统环境安装Docker CE容器的过程

    由于项目的需要,我们在很多软件配置环境中需要用到Docker容器,这个时候我们可以用自己的VPS主机搭建.在这篇文章中,笔者将会利用Ubuntu 16.04系统环境安装Docker CE容器的过程.如 ...

  4. Python基础-Python的三元运算符和lambda表达式

    1. Python的三元表达式: 现在大部分高级语言都支持 “?”这个三元运算符,它对应的表达式如下:condition ? value if true:value if else 但是 Python ...

  5. .net webService保存全局变量中

    遇到坑,然后找到解决方案,我就习惯做个记录. 情景:通过webservice调用一个第三方的库,在初始化第三方库的时候需要花费较长时间 目的:希望通过初始化一次,缓存下来,下次直接调用,而不必每次初始 ...

  6. DevExpress v18.2新版亮点——Reporting篇(二)

    行业领先的.NET界面控件——DevExpress v18.2日前正式发布,本站将以连载的形式为大家介绍新版本新功能.本文将介绍了DevExpress Reporting v18.2 的新功能,新版3 ...

  7. node.js 之 N-blog

    N-blog  使用 Express + MongoDB 搭建多人博客 原文地址: https://github.com/nswbmw/N-blog 建议初学者,研究下整个项目. 这里节选了一些内容为 ...

  8. OpenGL之纹理贴图(Texture)

    学习自: https://learnopengl-cn.github.io/01%20Getting%20started/06%20Textures/ 先上一波效果图: 实际上就是:画了一个矩形,然后 ...

  9. 北大poj- 1008

    Maya Calendar Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 80956   Accepted: 24892 D ...

  10. oracle 表空间不足处理

    linux环境将*.dmp文件导入数据库时,df  -h 发现测试环境虚拟机空间不足,而数据文件xxx.dbf所占空间达到40G左右,果断删除表空间重建在导入. 一.查出存储数据表空间名称 selec ...