P4172-[WC2006]水管局长【LCT,最小生成树】

正题

题目链接:https://www.luogu.com.cn/problem/P4172


题目大意

nnn个点的一张图,有两个操作

  1. 询问两个点之间的一条路径使得最长边最短
  2. 删除一条边

解题思路

显然这条边一定是在最小生成树上的,所以我们需要维护支持删边的最小生成树。

显然LCTLCTLCT无法支持删除,但是注意到只有删除操作,所以我们反着做的话就变成了加边操作,用LCTLCTLCT维护即可。


codecodecode

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<stack>
#define mp(x,y) make_pair(x,y)
using namespace std;
const int N=2e5+10,inf=2147483647;
int n,m,t,ans[N];
int from[N],w[N],val[N];
pair<pair<int,int> ,int>lk[N];
struct node{int x,y,w,id;bool del;
}e[N];
struct Query{int op,x,y;
}q[N];
struct LCT{stack<int> s;int fa[N],t[N][2],r[N];void PushUp(int x){from[x]=x;w[x]=val[x];if(t[x][0]&&w[t[x][0]]>w[x])w[x]=w[t[x][0]],from[x]=from[t[x][0]];if(t[x][1]&&w[t[x][1]]>w[x])w[x]=w[t[x][1]],from[x]=from[t[x][1]];return;}bool Nroot(int x){return fa[x]&&(t[fa[x]][0]==x||t[fa[x]][1]==x);}bool Direct(int x){return t[fa[x]][1]==x;}void Rev(int x){swap(t[x][0],t[x][1]);r[x]^=1;}void PushDown(int x){if(r[x])Rev(t[x][0]),Rev(t[x][1]),r[x]=0;return;}void Rotate(int x){int y=fa[x],z=fa[y];int xs=Direct(x),ys=Direct(y);int w=t[x][xs^1];if(Nroot(y))t[z][ys]=x;t[x][xs^1]=y;t[y][xs]=w;if(w)fa[w]=y;fa[y]=x;fa[x]=z;PushUp(y);PushUp(x);}void Splay(int x){int now=x;s.push(x);while(Nroot(now))now=fa[now],s.push(now);while(!s.empty())PushDown(s.top()),s.pop();while(Nroot(x)){int y=fa[x];if(!Nroot(y))Rotate(x);else if(Direct(x)==Direct(y))Rotate(y),Rotate(x);else Rotate(x),Rotate(x);}return;}void Access(int x){for(int y=0;x;y=x,x=fa[x])Splay(x),t[x][1]=y,PushUp(x);return; }void MakeRoot(int x){Access(x);Splay(x);Rev(x);return;}void Split(int x,int y){MakeRoot(x);Access(y);Splay(y);return;}void Link(int x,int y){MakeRoot(x);fa[x]=y;Access(x);return;}void Cut(int x,int y){MakeRoot(x);Access(y);Splay(y);fa[t[y][0]]=0;t[y][0]=0;PushUp(y);return;}
}LCT;
struct unionfind{int fa[N];int find(int x){return (fa[x]==x)?x:(fa[x]=find(fa[x]));}void unionn(int x,int y){int Fa=find(x),Fb=find(y);if(x<y)fa[y]=x;else fa[x]=y;return;}
}F;
bool CmP(node x,node y)
{return x.w<y.w;}
bool cMp(node x,node y)
{return x.id<y.id;}
int main()
{scanf("%d%d%d",&n,&m,&t);for(int i=1;i<=m;i++){scanf("%d%d%d",&e[i].x,&e[i].y,&e[i].w);if(e[i].x>e[i].y)swap(e[i].x,e[i].y);lk[i]=mp(mp(e[i].x,e[i].y),i);e[i].id=i;}sort(lk+1,lk+1+m);for(int i=1;i<=t;i++){scanf("%d%d%d",&q[i].op,&q[i].x,&q[i].y);if(q[i].x>q[i].y)swap(q[i].x,q[i].y);if(q[i].op==2){q[i].x=(*lower_bound(lk+1,lk+1+m,mp(mp(q[i].x,q[i].y),0))).second;e[q[i].x].del=1; } }for(int i=1;i<=n+m;i++)from[i]=i,val[i]=w[i]=-inf;for(int i=1;i<=n;i++)F.fa[i]=i;for(int i=1;i<=m;i++)val[i+n]=w[i+n]=e[i].w;sort(e+1,e+1+m,CmP);for(int i=1;i<=m;i++){if(e[i].del)continue;int Fa=F.find(e[i].x),Fb=F.find(e[i].y);if(Fa==Fb)continue;F.unionn(Fa,Fb);LCT.Link(e[i].x,e[i].id+n);LCT.Link(e[i].id+n,e[i].y);}sort(e+1,e+1+m,cMp);for(int i=t;i>=1;i--){if(q[i].op==1){LCT.Split(q[i].x,q[i].y);ans[i]=w[q[i].y];}else{int id=q[i].x,x,y;y=e[id].y;x=e[id].x;LCT.Split(x,y);if(w[y]>e[id].w){int w=from[y];LCT.Cut(w,e[w-n].y);LCT.Cut(e[w-n].x,w);LCT.Link(x,id+n);LCT.Link(id+n,y);}}}for(int i=1;i<=t;i++)if(q[i].op==1)printf("%d\n",ans[i]);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/320443.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

牛客OI周赛15-普及组

1. 咪咪游戏 bool f1,f2,f; f1用于记录m f2用于记录q f用于判断串的好坏。1为坏&#xff0c;0为好 注意几种情况&#xff1a; mqm mmq 具体看代码&#xff1a; #include<bits/stdc.h> using namespace std; int main() {int n;cin>>n;string s;while(n--){bool f10…

【单调栈】向右看齐(luogu 2947)

向右看齐 luogu 2947 题目大意&#xff1a; 有n头奶牛&#xff0c;它们各有各的高度&#xff0c;现在要求出每一头奶牛右边第一头比他高的奶牛是那一头 输入样例 6 3 2 6 1 1 2 输出样例 3 3 0 6 6 0 输入说明 6 头奶牛的身高分别为 3, 2, 6, 1, 1, 2. 输出…

Codeforces 786B Legacy (线段树优化建图)

Codeforces 786B Legacy (线段树优化建图) 题意&#xff1a;\(n\)个点&#xff0c;有\(3\)种连边操作&#xff1a;1.将\(u\)指向\(v\)&#xff1b;2.将\(v\)指向编号在区间\([l,r]\)的点&#xff1b;3.将\([l,r]\)中的所有点指向\(v\) 做法&#xff1a;线段树优化建图。拓展一些…

Abp + Grpc 如何实现用户会话状态传递

0.背景在实际项目当中&#xff0c;我采用的是 Abp 框架&#xff0c;但是 Abp 框架官方并没有针对 Grpc 进行模块封装。基于此我结合 Abp 与 MagicOnion 封装了一个 Abp.Grpc 模块&#xff0c;它包括服务端和调用端两部分的包。通过这两个包&#xff0c;你可以很方便地在 Abp 框…

P4197-Peaks【Kruskal重构树,主席树】

正题 题目链接:https://www.luogu.com.cn/problem/P4197 题目大意 nnn个点的一张无向图&#xff0c;每个点有一个hih_ihi​&#xff0c;边有权值。 qqq次询问从vvv出发不走权值超过xxx的路径能到达的第kkk大hih_ihi​是多少。 解题思路 构一颗KruskalKruskalKruskal重构树之后…

多项式相关操作学习笔记

多项式相关操作学习笔记 标签&#xff1a; 多项式 说在前边 记录一下相关的多项式操作&#xff0c;顺便存个模板。&#xff08;多点求值之后的部分&#xff0c;有点写不动了。。。留坑留坑 多项式 定义 给定一个环\(R\)(\(R\)通常是交换环&#xff0c;可以是有理数、实数或者复…

恢复数列

题目链接 比赛链接 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K Special Judge,64bit IO Format: %lld 题目描述 小y的数学作业不小心被泼上了墨水。有道题看不清了&#xff0c;现在他想请你帮他恢复这道…

【单调栈】Largest Rectangle in a Histogram(luogu-SP1805/poj 2559)

Largest Rectangle in a Histogram luogu-SP1805 poj 2559 题目大意&#xff1a; 有n个并排的矩阵&#xff0c;高度为aia_iai​&#xff0c;宽度为1&#xff0c;现在让求包含于这些矩阵的并集内部的最大矩阵的面积 输入样例 7 2 1 4 5 1 3 3 4 1000 1000 1000 1000 0输出…

【翻译】asp.net core中使用MediatR

这篇文章来自&#xff1a;https://ardalis.com/using-mediatr-in-aspnet-core-apps本文作为翻译&#xff0c;有一些单词翻译成中文可能会有一些误解&#xff08;对于读者&#xff09;或者错误&#xff08;对于作者&#xff09;的地方&#xff0c;所以在文章中你可以看到一些单词…

P2056-[ZJOI2007]捉迷藏【点分树,堆】

正题 题目链接:https://www.luogu.com.cn/problem/P2056 题目大意 nnn个点的一棵树&#xff0c;开始全是黑点&#xff0c;有操作 取反一个点的颜色求最远的黑点之间的距离 解题思路 根据点分治每个点和分散开来的重心连边&#xff0c;然后每个点往上只会有logloglog层节点。…

数论杂谈(欧拉定理与费马小定理结论与应用)

文章目录欧拉定理&#xff1a;欧拉定理性质&#xff1a;扩展欧拉定理&#xff1a;费马小定理&#xff1a;指数循环节费马大定理逆元&#xff1a;例题原根定义&#xff1a;原根存在条件例题快速幂代码矩阵快速幂原理&#xff1a;代码&#xff1a;欧拉定理&#xff1a; aφ(n)≡…

【队列】Team Queue(luogu-UVA540/poj 2259)

Team Queue luogu-UVA540 poj 2259 题目大意&#xff1a; 有n个小组的人要排队&#xff0c;每个小组中有若干个人&#xff0c;当一个人入队时&#xff0c;如果队中有自己小组的人就跟在此人后面&#xff0c;否则站在队尾&#xff0c;现在给出一些操作&#xff0c;让你去操作…

ASP.NET Core MVC with EF Core-迁移

当你开发一个新的应用程序的时候&#xff0c;你的模型频繁的变化&#xff0c;而每一次的数据模型的改变&#xff0c;将使它与数据库不同步。你通过配置EF Core&#xff0c;使得数据库不存在时创建数据库。每一次改变数据模型&#xff08;增删改 实体类或者改变DbContextClass),…

Gym102059A Coloring Roads

Gym102059A Coloring Roads 题意&#xff1a;\(n\)点的树&#xff0c;一开始每条边都没有颜色&#xff0c;有\(Q\)个操作&#xff0c;每次将从\(u\)到\(1\)路径上的所有边全部染色为颜色\(c\)&#xff0c;之后询问整棵树上&#xff0c;出现了\(m\)次的颜色有多少种。数据范围均…

【树形区间DP】加分二叉树(ssl 1033/luogu 1040)

加分二叉树 ssl 1033 luogu 1040 题目大意&#xff1a; 有一棵中序遍历为1,2,3…n的二叉树&#xff08;当然二叉树的样子没有固定&#xff09;&#xff0c;现在给出每个节点的分数&#xff0c;一个节点的加数两个子节点的加数相乘当前节点的分数&#xff08;空的子节点加数…

jzoj5699-[GDOI2018day1]涛涛接苹果【树套树】

正题 题目链接:https://gmoj.net/senior/#main/show/5699 题目大意 一棵树&#xff0c;每个节点有权值&#xff0c;每天所有权值会往它的父节点滑一位&#xff0c;然后有操作会在某一天的某个节点加权值。 然后询问若干次某个时间一个位置的子树权值和。 解题思路 因为每次…

【每日一题】4月8日题目精讲 黑白树

试题链接 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 32768K&#xff0c;其他语言65536K 64bit IO Format:%lld 题目描述 一棵n个点的有根树&#xff0c;1号点为根&#xff0c;相邻的两个节点之间的距离为1。树上每个节点i对应一个值k[i]。每…

C#中字段、属性、只读、构造函数赋值、反射赋值的相关

C#中字段、属性和构造函数赋值的问题提出问题首先提出几个问题&#xff1a;1、如何实现自己的注入框架&#xff1f;2、字段和自动属性的区别是什么&#xff1f;3、字段和自动属性声明时的直接赋值和构造函数赋值有什么区别&#xff1f;4、为什么只读字段和只读自动属性&#xf…

点分治学习笔记

点分治学习笔记 模板题[洛谷P3806] 题意&#xff1a;给定一棵有n个点的树&#xff0c;询问树上距离为k的点对是否存在。 做法&#xff1a;对于一个点\(u\)&#xff0c;树上所有的路径可以分为两类&#xff0c;一类是经过点\(u\)&#xff0c;另一类是没有经过点\(u\)&#xff0c…

【暴力】心中报情(jzoj 2317)

心中报情 jzoj 2317 题目大意&#xff1a; 在一个n*m矩阵中&#xff0c;有k个选定的子矩阵&#xff0c;每个矩阵有一个代价&#xff0c;现在让你选两个子矩阵&#xff08;有相交的&#xff09;&#xff0c;使他们覆盖的元素之和减去他两的代价最大&#xff08;重复的只算一次…