poj 2377 拉最长的线问题 kruskal算法

Posted xuxiaojin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了poj 2377 拉最长的线问题 kruskal算法相关的知识,希望对你有一定的参考价值。

题意:建光纤的时候,拉一条最长的线

思路:最大生成树 

  1. 将图的n个顶点看成n个孤立的连通分支,并将所有的边按权从大到小排
  2. 边权递减的顺序,如果加入边的两个端点不在同一个根节点的话加入,并且要将其连通,否则放弃
  3. 最后剩下一个连通支

解决问题的代码:

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<vector>
#include<queue>
#include<map>
#include<set>
#include<ctime>
using namespace std;
typedef long long ll;
#define maxn 1111
#define maxm 22222
struct node
{
    int u,v,w;
}edge[maxm];
int T,n,m,fa[maxn];
int cmp(node a,node b)
{
    return a.w>b.w;
}
int find(int x)
{
    if(fa[x]==x) return x;
    return fa[x]=find(fa[x]);
}
int kruskal(int n,int m)
{
    for(int i=1;i<=n;i++)fa[i]=i;
    int ans=0,cnt=0;
    sort(edge,edge+m,cmp);
    for(int k=0;k<m;k++)
    {
        int x=find(edge[k].u),y=find(edge[k].v);
        if(x!=y)
        {
            cnt++;
            fa[x]=y;
            ans+=edge[k].w;
            if(cnt==n-1)return ans;
        }
    }
    return -1;
}
int main()
{
    while(~scanf("%d%d",&n,&m))
    {
        for(int i=0;i<m;i++)scanf("%d%d%d",&edge[i].u,&edge[i].v,&edge[i].w);
        printf("%d
",kruskal(n,m));
    }
    return 0;
}

 

以上是关于poj 2377 拉最长的线问题 kruskal算法的主要内容,如果未能解决你的问题,请参考以下文章

POJ 2377 Bad Cowtractors (Kruskal)

ZOJ 1542 POJ 1861 Network 网络 最小生成树,求最长边,Kruskal算法

POJ 2253 Frogger最短路变形/kruskal/A到B多条路径中的最小的最长边

POJ2377

Bad Cowtractors POJ - 2377

PKUACM 2018 D Chocolate 最小生成树 Kruskal 最长公共子序列