P4172 [WC2006]水管局长

前言

luogu数据太小

去bzoj,他的数据大一些

思路

正着删不好维护

那就倒着加,没了

LCT维护他的最小生成树MST

树上加一条边肯定会有一个环

看看环上最大值和加边的大小

然后选择加不加,改不改

错误

哇,恶心撒

怼着题解都写不出来

最后乱改了一下就A了???

代码

// luogu-judger-enable-o2
#include <bits/stdc++.h>
#define ls ch[x][0]
#define rs ch[x][1]
#define FOR(i,a,b) for(int i=a;i<=b;++i)
using namespace std;
const int N=1e6+7;
const int inf=0x3f3f3f3f;
int read() {
int x=0,f=1;char s=getchar();
for(;s>'9'||s<'0';s=getchar()) if(s=='-') f=-1;
for(;s>='0'&&s<='9';s=getchar()) x=x*10+s-'0';
return x*f;
}
int n,m,qwq,ans[N];
map<int,int> MVP[N];
//MVP[1200][1200]; luogu
struct node {
int u,v,q,id;
bool operator < (const node &b) const {
return q<b.q;
}
}G[N];
map<pair<int,int>,int> mdzz;
struct query {
int opt,x,y,id;
}Q[N];
int f[N],ch[N][2],s[N],lazy[N];
int val[N];
void pushup(int x) {
s[x]=x;
if(val[s[ls]] > val[s[x]]) s[x]=s[ls];
if(val[s[rs]] > val[s[x]]) s[x]=s[rs];
}
void tag(int x) {
swap(ls,rs);
lazy[x]^=1;
}
bool isroot(int x) {
return ch[f[x]][0]==x || ch[f[x]][1]==x;
}
void pushdown(int x) {
if(lazy[x]) {
if(ls) tag(ls);
if(rs) tag(rs);
lazy[x]=0;
}
}
void rotate(int x) {
int y=f[x],z=f[y],k=ch[y][1]==x,m=ch[x][k^1];
if(isroot(y)) ch[z][ch[z][1]==y]=x;
ch[x][k^1]=y;
ch[y][k]=m;
if(m) f[m]=y;
f[x]=z;
f[y]=x;
pushup(y);
}
int q[N];
void splay(int x) {
int y=x,z=0;
q[++z]=y;
while(isroot(y)) q[++z]=y=f[y];
while(z) pushdown(q[z--]);
while(isroot(x)) {
y=f[x],z=f[y];
if(isroot(y)) (ch[y][1]==x)^(ch[z][1]==y) ? rotate(x) : rotate(y);
rotate(x);
}
pushup(x);
}
void access(int x) {
for(int y=0;x;y=x,x=f[x])
splay(x),rs=y,pushup(x);
}
void makeroot(int x) {
access(x);
splay(x);
tag(x);
}
int findroot(int x) {
access(x);
splay(x);
while(ls) pushdown(x),x=ls;
return x;
}
int split(int x,int y) {
makeroot(x);
access(y);
splay(y);
return s[y];
}
void link(int x,int y) {
makeroot(x);
if(findroot(y)!=x) f[x]=y;
}
void cut(int x,int y) {
makeroot(x);
if(findroot(y)==x&&f[x]==y&&!ch[x][1]) {
f[x]=ch[y][0]=0;
pushup(y);
}
}
int suanle_f[N],suanle_siz[N];
int suanle_find(int x) {
return suanle_f[x]==x ? x : suanle_f[x]=suanle_find(suanle_f[x]);
}
void suanle_uu(int x,int y) {
int fx=suanle_find(x),fy=suanle_find(y);
if(suanle_siz[fx] <= suanle_siz[fy]) {
suanle_f[fx]=fy;
if(suanle_siz[fx]==suanle_siz[fy]) suanle_siz[fy]++;
} else {
suanle_f[fy]=fx;
}
}
int main() {
// freopen("a.in","r",stdin);
// freopen("a.out","w",stdout);
n=read(),m=read(),qwq=read();
FOR(i,1,m) suanle_f[i]=i;
FOR(i,1,m) {
G[i].u=read(),G[i].v=read(),G[i].q=read();
if(G[i].u>G[i].v)swap(G[i].u,G[i].v);
}
sort(G+1,G+1+m);
FOR(i,1,m) val[i+n]=G[i].q,mdzz[make_pair(G[i].u,G[i].v)]=i,s[n+i]=n+i;
FOR(i,1,qwq) {
Q[i].opt=read(),Q[i].x=read(),Q[i].y=read();
if(Q[i].x>Q[i].y)swap(Q[i].x,Q[i].y);
if(Q[i].opt==2) {
Q[i].id=mdzz[make_pair(Q[i].x,Q[i].y)];
MVP[Q[i].x][Q[i].y]=1;
}
}
FOR(i,1,m) val[i+n]=G[i].q;
int js=0;
FOR(i,1,m) {
if(MVP[G[i].u][G[i].v]==1) continue;
if(suanle_find(G[i].u)==suanle_find(G[i].v)) continue;
link(G[i].u,i+n);
link(G[i].v,i+n);
suanle_uu(G[i].u,G[i].v);
js++;
if(js==n-1) break;
}
for(int i=qwq;i>=1;--i) {
int x=Q[i].x,y=Q[i].y;
if(Q[i].opt==1) {
int tmp=split(x,y);
ans[i]=val[tmp];
} else {
int tmp=split(x,y);
if(val[tmp] > G[Q[i].id].q) {
cut(G[tmp-n].u,tmp);
cut(G[tmp-n].v,tmp);
link(x,Q[i].id+n);
link(y,Q[i].id+n);
}
}
}
FOR(i,1,qwq) if(Q[i].opt==1) cout<<ans[i]<<"\n";
return 0;
}

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

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

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

  2. 洛谷P4172 [WC2006]水管局长(lct求动态最小生成树)

    SC省MY市有着庞大的地下水管网络,嘟嘟是MY市的水管局长(就是管水管的啦),嘟嘟作为水管局长的工作就是:每天供水公司可能要将一定量的水从x处送往y处,嘟嘟需要为供水公司找到一条从A至B的水管的路径, ...

  3. P4172 [WC2006]水管局长 LCT维护最小生成树

    \(\color{#0066ff}{ 题目描述 }\) SC 省 MY 市有着庞大的地下水管网络,嘟嘟是 MY 市的水管局长(就是管水管的啦),嘟嘟作为水管局长的工作就是:每天供水公司可能要将一定量的 ...

  4. luogu P4172 [WC2006]水管局长 LCT维护动态MST + 离线

    Code: #include<bits/stdc++.h> #define maxn 1200000 #define N 120000 using namespace std; char ...

  5. [洛谷P4172] WC2006 水管局长

    问题描述 SC省MY市有着庞大的地下水管网络,嘟嘟是MY市的水管局长(就是管水管的啦),嘟嘟作为水管局长的工作就是:每天供水公司可能要将一定量的水从x处送往y处,嘟嘟需要为供水公司找到一条从A至B的水 ...

  6. 洛谷P4172 [WC2006]水管局长 (LCT,最小生成树)

    洛谷题目传送门 思路分析 在一个图中,要求路径上最大边边权最小,就不难想到最小生成树.而题目中有删边的操作,那肯定是要动态维护啦.直接上LCT维护边权最小值(可以参考一下蒟蒻的Blog) 这时候令人头 ...

  7. Luogu P4172 [WC2006]水管局长

    题意 给定一个 \(n\) 个点 \(m\) 条边的图和 \(q\) 次操作,每次操作分为以下两种: 1 u v:查询 \(u\) 到 \(v\) 的一条路径使得边权最大的边的权值最小. 2 u v: ...

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

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

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

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

随机推荐

  1. __init__.py的作用

    __init__.py 文件定义了包的属性和方法.其实它可以什么也不定义:可以只是一个空文件,但是必须存在.如果 __init__.py 不存在,这个目录就仅仅是一个目录,而不是一个包,它就不能被导入 ...

  2. caffe-ssd运行create_data.sh的时候报错:SSD from caffe.proto import caffe_pb2 ImportError: No module named caffe.proto

    在用voc2007和voc2012的数据训练基于caffe的SSD模型的时候,我们需要将图片数据转换成lmdb格式,运行脚本文件是SSD源码里面提供的create_data.sh(具体位置在$CAFF ...

  3. JSP—简介

    BS/CS的区别? CS模式: client:客户端:存放操作界面的图片样式本地数据和缓存等 server:服务端:保存核心数据 请求响应模式:收到请求后,服务器只需要返回核心的数据 优缺点:需要安装 ...

  4. vm虚拟机黑屏解决办法

    以管理员打开cmd 输入 netsh winsock reset --------------------- 然后 reboot

  5. Python全栈-数据库存储引擎

    一.存储引擎概述 在个人PC机中,不同的文件类型有不同的处理机制进从存取,例如文本用txt打开.保存:表格用excel读.写等.在数据库中,同时也存在多种类型的表,因此数据库操作系统中也应拥有对各种表 ...

  6. How to compute f1 score for each epoch in Keras

    https://medium.com/@thongonary/how-to-compute-f1-score-for-each-epoch-in-keras-a1acd17715a2 https:// ...

  7. Locust 设置响应断言

    转:http://www.testclass.net/locust/assert/ 性能测试也需要设置断言么? 某些情况下是需要,比如你在请求一个页面时,就可以通过状态来判断返回的 HTTP 状态码是 ...

  8. python 网页cookie的使用

    网页cookie的使用 Cookie,指某些网站为了辨别用户身份.进行session跟踪而储存在用户本地终端上的数据(通常经过加密) # opener的概念当你获取一个URL你使用一个opener(一 ...

  9. Autel Maxisys MS908CV Description

    The new Autel MaxiSys CV Heavy Duty Diagnostic is built on the powerful MaxiSys 908 platform and pro ...

  10. Python+OpenCV图像处理(六)—— ROI与泛洪填充

    一.ROI ROI(region of interest),感兴趣区域.机器视觉.图像处理中,从被处理的图像以方框.圆.椭圆.不规则多边形等方式勾勒出需要处理的区域,称为感兴趣区域,ROI. 代码如下 ...