码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2018-08-02 16:53:50      阅读:118      评论:0      收藏:0      [点我收藏+]

标签:using   cti   type   find   代码   题意   main   顶点   放弃   

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

思路:最大生成树 

  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\n",kruskal(n,m));
    }
    return 0;
}

 

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

标签:using   cti   type   find   代码   题意   main   顶点   放弃   

原文地址:https://www.cnblogs.com/xuxiaojin/p/9407962.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!