HLGOJ 1133 MST(kruskal)

本文介绍了一种简洁的Kruskal算法实现方法,用于解决最小生成树问题。通过C++代码展示了如何通过并查集高效地找到不形成环路的边集合,并最终计算出最小生成树的权重总和。

全裸的kruskal解决问题。

代码:

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define maxn 100

struct Edge
{
    int from, to, data;
};

Edge edges[maxn*maxn/2];

bool cmp(const Edge a, const Edge b)
{
    return a.data<b.data;
}

int p[maxn+10];

int fa(int x)
{
    return p[x]==x? x : p[x] = fa(p[x]);
}

int main()
{
    int n;
    while(scanf("%d", &n),n)
    {
        for(int i = 0; i <= n; i++) p[i] = i;
        for(int i = 0; i < n*(n-1)/2; i++)
        {
            scanf("%d%d%d", &edges[i].from, &edges[i].to, &edges[i].data);
        }

        sort(edges, edges + n*(n-1)/2, cmp);
        //for(int i = 0; i<cnt; i++)
        {

            // printf("->%d\n", edges[i].data);
        }
        int ans = 0;
        int cnt1 = 1;
        for(int i = 0; i < n*(n-1)/2; i++)
        {
            int x = fa(edges[i].from);
            int y = fa(edges[i].to);

            if(x!=y)
            {
                ans += edges[i].data;
                p[x] = y;
                cnt1++;
            }
            if(cnt1==n) break;
        }
        printf("%d\n", ans);

    }
    return 0;
}


代码下载地址: https://pan.quark.cn/s/35e46f7e83fb 关于 Build Status Lines of code 这是一个参考 PotPlayer 的界面使用 Java 以及图形界面框架 JavaFX 使用 MCV 图形界面与业务逻辑分离的开发模式, 所开发的个人视频播放器项目, 开发这个项目旨在于学习图形界面框架 JavaFX 实现了具有和 PotPlayer相同 的简洁界面和流畅的操作逻辑。 Note: PotPlayer 是 KMPlayer 的原制作者姜龙喜先生(韩国)进入 Daum 公司后的 新一代网络播放器, PotPlayer的优势在于强大的内置解码器以及支持各类的 视频格式, 而且是免费下载提供使用的。 目前版本: 2020/10/28 v1.0.0 [x] 支持打开文件自动播放 [x] 支持查看播放记录 [x] 支持屏幕边沿窗口自动吸附 [x] 支持双击视频来播放和暂停 [x] 支持左键点击窗口任意位置来拖到窗口 [x] 支持左键双击播放窗口打开文件 [x] 支持根据视频尺寸自动调整窗口大小 [x] 支持根据播放文件类型调整窗口模式 [x] 支持根据视频尺寸自动调整窗口显示位置防止超出屏幕 [x] 支持记录上一次访问的文件路径 [x] 支持播放记录文件读写 已实现样式 未播放效果: 播放效果: 运行环境 本项目使用 NetBeans 配合 JDK 开发, NetBeans8.0 以及 JDK8.0 以上版本的均可以运行。 亦可使用其他集成开发环境, 例如 Eclipse, IntelliJ IDEA 配合使用 JDK8.0 以上版本均可构建此项目。 NetBeans download Eclipse downlo...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值