HDOJ1233 畅通工程之一(最小生成树-Kruscal)

简介:

题目:

  1233 还是畅通工程
复制代码
 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <algorithm>
 5 using namespace std;
 6 
 7 #define M 101
 8 typedef struct{
 9     int x,y;
10     int len;
11 }EDGE;
12 
13 EDGE edge[M*M];
14 int Map[M][M];
15 int n,m;
16 int set[M];
17 
18 void ReadMap();
19 void InitSet();
20 int cmp(const EDGE &a,const EDGE &b);
21 int FindSet(int a);
22 void MergeSet(int a,int b);
23 void main()
24 {
25     int c,s,f,t;
26     while (scanf("%d",&n),n)
27     {
28         m = (n*(n-1))>>1;
29         ReadMap();
30         InitSet();
31         c = 0;//choosed node
32         s = 0;//sum length
33         sort(edge,edge+m,cmp);//sort the edges
34         for (int i=0;i<m && c!=n;i++)
35         {
36             f = FindSet(edge[i].x);
37             t = FindSet(edge[i].y);
38             if (f!=t)
39             {
40                 MergeSet(f,t);
41                 c++;
42                 s += edge[i].len;
43             }
44         }
45         cout<<s<<endl;
46 
47     }
48 }
49 void ReadMap()
50 {
51     for (int i=0;i<m;i++)
52         cin>>edge[i].x>>edge[i].y>>edge[i].len;
53 }
54 void InitSet()
55 {
56     for (int i=1;i<=n;i++)
57         set[i] = i;
58 }
59 int cmp(const EDGE &a,const EDGE &b)
60 {
61     return a.len<b.len;
62 }
63 int FindSet(int a)
64 {
65     return set[a];
66 }
67 void MergeSet(int a,int b)
68 {
69     for (int i=1;i<=n;i++)
70     {
71         if (set[i] == a)
72         {
73             set[i] = b;
74         }
75     }
76 }
复制代码

 


本文转自ZH奶酪博客园博客,原文链接:http://www.cnblogs.com/CheeseZH/archive/2012/10/09/2716903.html,如需转载请自行联系原作者

相关文章
|
3天前
|
云安全 人工智能 自然语言处理
|
7天前
|
人工智能 Java API
Java 正式进入 Agentic AI 时代:Spring AI Alibaba 1.1 发布背后的技术演进
Spring AI Alibaba 1.1 正式发布,提供极简方式构建企业级AI智能体。基于ReactAgent核心,支持多智能体协作、上下文工程与生产级管控,助力开发者快速打造可靠、可扩展的智能应用。
755 17
|
11天前
|
数据采集 人工智能 自然语言处理
Meta SAM3开源:让图像分割,听懂你的话
Meta发布并开源SAM 3,首个支持文本或视觉提示的统一图像视频分割模型,可精准分割“红色条纹伞”等开放词汇概念,覆盖400万独特概念,性能达人类水平75%–80%,推动视觉分割新突破。
783 59
Meta SAM3开源:让图像分割,听懂你的话
|
1天前
|
人工智能 安全 小程序
阿里云无影云电脑是什么?最新收费价格个人版、企业版和商业版无影云电脑收费价格
阿里云无影云电脑是运行在云端的虚拟电脑,分企业版和个人版。企业版适用于办公、设计等场景,4核8G配置低至199元/年;个人版适合游戏、娱乐,黄金款14元/月起。支持多端接入,灵活按需使用。
231 164
|
8天前
|
搜索推荐 编译器 Linux
一个可用于企业开发及通用跨平台的Makefile文件
一款适用于企业级开发的通用跨平台Makefile,支持C/C++混合编译、多目标输出(可执行文件、静态/动态库)、Release/Debug版本管理。配置简洁,仅需修改带`MF_CONFIGURE_`前缀的变量,支持脚本化配置与子Makefile管理,具备完善日志、错误提示和跨平台兼容性,附详细文档与示例,便于学习与集成。
330 116
|
2天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
300 3
|
6天前
|
弹性计算 搜索推荐 应用服务中间件
阿里云服务器租用价格:一年、1小时及一个月收费标准及优惠活动参考
阿里云服务器优惠汇总:轻量应用服务器200M带宽38元/年起,ECS云服务器2核2G 99元/年、2核4G 199元/年,4核16G 89元/月,8核32G 160元/月,香港轻量服务器25元/月起,支持按小时计费,新老用户同享,续费同价,限时秒杀低至1折。
402 166

热门文章

最新文章