ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

kruskal模板

2022-01-18 16:34:02  阅读:138  来源: 互联网

标签:5010 cnt return cout int kruskal edge 模板


Prim

#include<bits/stdc++.h>
using namespace std;
int n,m,cnt,ans;
bool b[5010];
struct edge
{
	int x,w;
	bool operator<(const edge &a)const
	{
		return w>a.w;
	}
};
vector<edge> v[5010];
priority_queue<edge> q;
int main()
{
	cin>>n>>m;
	for(int i=1,x,y,w;i<=m;i++)
	{
		cin>>x>>y>>w;
		v[y].push_back(edge{x,w});
		v[x].push_back(edge{y,w});
	}
	b[1]=1;
	cnt=1;
	for(int i=0;i<v[1].size();i++)q.push(edge{v[1][i].x,v[1][i].w});
	while(cnt<n)
	{
		if(q.empty())
		{
			cout<<"orz";
			return 0;
		}
		edge t=q.top();
		q.pop();
		if(b[t.x])continue;
		b[t.x]=1;
		cnt++;
		ans+=t.w;
		for(int i=0;i<v[t.x].size();i++)
		{
			if(!b[v[t.x][i].x])q.push(edge{v[t.x][i].x,v[t.x][i].w});
		}
	}
	cout<<ans;
	return 0;
}

Kruskal

#include<bits/stdc++.h>
using namespace std;
int n,m,ans,f[5010],cnt;
struct edge
{
	int x,y,w;
}a[200010];
void init()
{
    for(int i=1;i<=n;i++)f[i]=i;
}
int find(int x)
{
    if(f[x]==x)return x;
    else return f[x]=find(f[x]);
}
void c(int x)
{
    int fx=find(a[x].x),fy=find(a[x].y);
    if(fx==fy)return ;
    cnt--;
    f[fx]=fy;
    ans+=a[x].w;
}
bool cmp(edge a,edge b)
{
	return a.w<b.w;
}
int main()
{
	cin>>n>>m;
	init();
	for(int i=1;i<=m;i++)cin>>a[i].x>>a[i].y>>a[i].w;
	sort(a+1,a+m+1,cmp);
	cnt=n;
	for(int i=1;i<=m;i++)c(i);
	if(cnt>1)cout<<"orz";
	else cout<<ans;
	return 0;
}

标签:5010,cnt,return,cout,int,kruskal,edge,模板
来源: https://blog.csdn.net/weixin_53960663/article/details/122562606

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有