[HDOJ1301]Jungle Roads

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1301

 

最小生成树 (Kruskal)

复制代码
 1 #pragma warning(disable:4996)
 2 #include <algorithm>
 3 #include <iostream>
 4 #include <iomanip>
 5 #include <cstring>
 6 #include <climits>
 7 #include <complex>
 8 #include <fstream>
 9 #include <cassert>
10 #include <cstdio>
11 #include <bitset>
12 #include <vector>
13 #include <deque>
14 #include <queue>
15 #include <stack>
16 #include <ctime>
17 #include <set>
18 #include <map>
19 #include <cmath>
20 
21 using namespace std;
22 
23 typedef struct Node {
24     int a;
25     int b;
26     int v;
27     friend bool operator < (Node a, Node b) {
28         return a.v > b.v;
29     }
30 }Node;
31 
32 const int maxn = 20010;
33 int pre[maxn];
34 int n, ans;
35 Node p;
36 priority_queue<Node> pq;
37 
38 int find(int x) {
39     return x == pre[x] ? x : pre[x] = find(pre[x]);
40 }
41 
42 bool unite(int x, int y) {
43     x = find(x);
44     y = find(y);
45     if (x != y) {
46         pre[y] = x;
47         return true;
48     }
49     return false;
50 }
51 inline void init() {
52     for (int i = 0; i < maxn; i++) {
53         pre[i] = i;
54     }
55     while (!pq.empty())    pq.pop();
56 }
57 
58 int main() {
59     // freopen("in", "r", stdin);
60     while (~scanf("%d", &n) && n) {
61         init();
62         char a[2], b[2];
63         int cnt = 0;
64         int m, v;
65         ans = 0;
66         n--;
67         for (int i = 0; i < n; i++) {
68             scanf("%s %d", &a, &m);
69             for (int i = 0; i < m; i++) {
70                 scanf("%s %d", &b, &v);
71                 p.a = a[0] - 'A';
72                 p.b = b[0] - 'A';
73                 p.v = v;
74                 pq.push(p);
75             }
76         }
77         while (n) {
78             p = pq.top();
79             pq.pop();
80             if (unite(p.a, p.b)) {
81                 n--;
82                 ans += p.v;
83             }
84         }
85         printf("%d\n", ans);
86     }
87 }
复制代码

 

posted @   Kirai  阅读(137)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core GC计划阶段(plan_phase)底层原理浅谈
· .NET开发智能桌面机器人:用.NET IoT库编写驱动控制两个屏幕
· 用纯.NET开发并制作一个智能桌面机器人:从.NET IoT入门开始
· 一个超经典 WinForm,WPF 卡死问题的终极反思
· ASP.NET Core - 日志记录系统(二)
阅读排行:
· 支付宝事故这事儿,凭什么又是程序员背锅?有没有可能是这样的...
· 在线客服系统 QPS 突破 240/秒,连接数突破 4000,日请求数接近1000万次,.NET 多
· C# 开发工具Visual Studio 介绍
· 在 Windows 10 上实现免密码 SSH 登录
· C#中如何使用异步编程
点击右上角即可分享
微信分享提示