网络稳定性--LCA+最大生成树+bfs1/dfs1找最小边

1.最大生成树去除重边,只要最大的边成树

2.LCA查最近公共祖先,然后询问的lca(x,y)=ff,分别从x,y向上找最小边

3.bfs1/dfs1就是2.中向上找的具体实现

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define N 100011
typedef  long long ll;
typedef pair<ll,int> pii;
int n,m,q;
int ff,mi;
int faa[N];
typedef struct edge
{
	int v;int w;
} edge;
typedef struct ed
{
	int u,v;int w;
} ed;
struct cmp
{
	bool operator()(const ed &a,const ed &b)const
	{
		return a.w<b.w;
	}
};
int find(int x)
{
	if(faa[x]==x) return x;
	return faa[x]=find(faa[x]);
}
priority_queue<ed,vector<ed>,cmp> pq;///克鲁斯卡尔 
 int x,y;
 vector<edge> mp[N];
 vector<edge> vp[N];
 int fa[N][25];
 int d[N];
 void bfs1(int x)///bfs1和dfs1一样作用,从下往上找最小边 
 {
 	queue<int> q;
 	q.push(x);
 	while(q.size())
 	{
 		int t=q.front();
 		q.pop();
 		if(t==ff) break;
 		for(int i=0;i<mp[t].size();i++)
 		{
 			int v=mp[t][i].v;
 			if(d[v]<d[t])
 			{
 				mi=min(mp[t][i].w,mi);
 				q.push(v);
			}
		}
	}
 }
  void dfs1(int x)
 {
     if(x==ff) return;///很重要,这里要return;停下来 
     for(int i=0;i<mp[x].size();i++)
     {
         int v=mp[x][i].v;
         if(d[v]<d[x])
         {
             mi=min(mp[x][i].w,mi);
             dfs1(v);
        }
     }
 }
 void dfs(int u,int f)///LCA的dfs 
 {
 	d[u]=d[f]+1;
 	fa[u][0]=f;
 	for(int i=1;i<=19;i++)
 	{
 		fa[u][i]=fa[fa[u][i-1]][i-1];
	}
	 for(int i=0;i<mp[u].size();i++)
	 {
	 	int v=mp[u][i].v;
	 	if(v!=f)
	 	{
	 		dfs(v,u);
		}
	 }
 }
 int lca(int s,int t)///LCA 
 {
 	if(d[s]<d[t]) swap(s,t);
 	for(int i=19;i>=0;i--)
 	{
 		if(d[fa[s][i]]>=d[t])
 		{
 			s=fa[s][i];
		 }
	 }
	 if(s==t) return  s;
	 for(int i=19;i>=0;i--)
	 {
	 	if(fa[s][i]!=fa[t][i])
	 	{
	 		s=fa[s][i];
	 		t=fa[t][i];
		 }
	 }
	 return fa[s][0];
 }
int main()
{
	ios::sync_with_stdio(0);
	cout.tie(0);
	cin.tie(0);
	cin>>n>>m>>q;
	for(int i=1;i<=n;i++) faa[i]=i;
	 for(int i=0;i<m;i++)
	 {
	 	int u,v, w;
	 	cin>>u>>v>>w;
	 	pq.push({u,v,w});
		vp[u].push_back({v,w});
		vp[v].push_back({u,w});
	 }
	 while(pq.size())///最大生成树去除重边,只取最大 
	 {
	 	ed e=pq.top();
	 	pq.pop();
	 	if(find(e.u)!=find(e.v))
	 	{
	 		mp[e.u].push_back({e.v,e.w});
	 		mp[e.v].push_back({e.u,e.w});
	 		faa[find(e.u)]=find(e.v);
		}
	 }
	 dfs(1,0);
	 for(int i=0;i<q;i++)
	 {
	 	mi=0x3f3f3f3f;
	 	cin>>x>>y;
	 	ff=lca(x,y);///最近公共祖先 
	 	dfs1(x);
	 	dfs1(y);
	 	if(mi>=0x3f3f3f3f) cout<<-1<<endl;///特殊情况 
	 	else  cout<<mi<<endl;
	 }
    return 0;
}
相关推荐
zhang133830890755 分钟前
CG-09H 超声波风速风向传感器 加热型 ABS材质 重量轻 没有机械部件
大数据·运维·网络·人工智能·自动化
酣大智1 小时前
接口模式参数
运维·网络·网络协议·tcp/ip
24zhgjx-lxq2 小时前
华为ensp:MSTP
网络·安全·华为·hcip·ensp
ling___xi2 小时前
《计算机网络》计网3小时期末速成课各版本教程都可用谢稀仁湖科大版都可用_哔哩哔哩_bilibili(笔记)
网络·笔记·计算机网络
REDcker2 小时前
Linux 文件描述符与 Socket 选项操作详解
linux·运维·网络
Up九五小庞3 小时前
用arpspoof实现100%批量切断192.168.110.10 - 192.168.110.100 断网(双向欺骗)--九五小庞
网络·开源
躺柒3 小时前
读数字时代的网络风险管理:策略、计划与执行04风险指引体系
大数据·网络·信息安全·数字化·网络管理·网络风险管理
独角鲸网络安全实验室3 小时前
本地信任成“致命漏洞”:数千Clawdbot Agent公网裸奔,供应链与内网安全告急
网络·网关·安全·php·漏洞·clawdbot·信任机制漏洞
ai_xiaogui3 小时前
Tailscale实现家庭与公司网络双向通信教程:子网路由配置详解
网络·tailscale·双向通信·子网路由配置详解·tailscale双向互访
mftang4 小时前
现代互联网安全的基石: SSL/TLS技术介绍
服务器·网络·ssl