博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hdu 3367 Pseudoforest(最大生成树)
阅读量:6579 次
发布时间:2019-06-24

本文共 942 字,大约阅读时间需要 3 分钟。

/*  可以说是一个最大生成树的问题吧,

    题意:求出一个最大的子图(子图的每个连通分量最多有一个环)

   用kruskal算法求出最大生成树  不过要判断是否有环  2树合并时 :若2个子树都有环不能合并 只有一个有环可以合并 但合并后的树有环 若2个子树都没环直接合并

*/

#include<cstdio>

#include<cstring>

#include<algorithm>
using namespace std;
int n,m;
struct Edge
{
    int u,v,d;
    bool operator < (const Edge &s) const
    {
        return d>s.d;
    }
}a[100010];
int p[10010],vis[10010];
int find(int x)
{
    return p[x]==x?x:p[x]=find(p[x]);
}
int Union(int x,int y)
{
    if(x==y) return 0;
    p[x] = y;
}
int main()
{
    while(scanf("%d%d",&n,&m)==2)
    {
        if(!n&&!m) break;
        memset(vis,0,sizeof(vis));
        for(int i = 0; i <= n; i++) p[i]=i;
        for(int i = 0; i < m; i++)
        scanf("%d%d%d",&a[i].u,&a[i].v,&a[i].d);
        sort(a,a+m);
        long long ans=0;
        for(int i = 0; i < m; i++)
        {
            int x = find(a[i].u);
            int y = find(a[i].v);
            if(x!=y)
            {
                if(vis[x]&&vis[y]) continue;
                if(vis[x]||vis[y])
                vis[x]=vis[y]=1;
                ans+=a[i].d;
                Union(x,y);
            }
            else if(!vis[x])
            {
                vis[x] = 1;
                ans+=a[i].d;
                Union(x,y);
            }
        }
        printf("%lld\n",ans);
    }
    return 0;
}

转载地址:http://fcnno.baihongyu.com/

你可能感兴趣的文章
Grunt 快速入门
查看>>
Spring cloud
查看>>
转:jdk动态代理实现
查看>>
手动修改/etc/shadow和/etc/passwd中的用户密码
查看>>
数据库的sacle-up和scale-out与sharding技术区分
查看>>
java 中的重载与重写 抽象类与接口的区别
查看>>
学习linux的一些指令
查看>>
android xml的生成与解析
查看>>
用jQuery编写简单九宫格抽奖
查看>>
IO模型
查看>>
Viewpager 的相关总结
查看>>
从INT 到STRING的几种方法
查看>>
管理软件供应商
查看>>
客户需要看到实物的样子,再去操作体验才知道是不是自己想要的.
查看>>
args[0]
查看>>
关于进程间通信的总结(IPC)
查看>>
short url
查看>>
Java中的异常
查看>>
我的校招季大概也是结束了。
查看>>
Docker 笔记
查看>>