MLE30分求助
查看原帖
MLE30分求助
428358
Grisses楼主2022/1/24 13:42
#include<bits/stdc++.h>
using namespace std;
int n,m,fa[40005];
struct node{
	int x,y,c;
	bool operator<(const node &t)const{
		return c>t.c;
	}
}a[100005];
int find(int x){
	if(fa[x]==x)return x;
	else return fa[x]=find(fa[x]);
}
int main()
{
	cin>>n>>m;
	for(int i=1;i<=m;i++)cin>>a[i].x>>a[i].y>>a[i].c;
	sort(a+1,a+m+1);
	for(int i=1;i<=n*2;i++)fa[i]=i;
	for(int i=1;i<=m;i++){
		int c=find(a[i].x+n),d=find(a[i].y+n);
		if(c==d){
			cout<<a[i].c;
			return 0;
		}
		fa[c]=fa[a[i].y];
		fa[d]=fa[a[i].x];
	}
	cout<<0;
	return 0;
}
2022/1/24 13:42
加载中...