首页 > 其他 > 详细

uva 1395(kruskal变形)

时间:2014-02-09 16:01:41      阅读:336      评论:0      收藏:0      [点我收藏+]

题意:这道题重新定义了最小生成树的含义是生成树中最小的边和最大的边的差值。然后给你一个无向带权图,让你输出最小生成树的值。若没有输出-1。

思路:很简单稍微想一下就可以知道,我们只要枚举生成树中最小的那条边然后在这个基础上求最小生成树,这样每次更新最小值,最终就能得到答案。

代码如下:

bubuko.com,布布扣
 1 /**************************************************
 2  * Author     : xiaohao Z
 3  * Blog     : http://www.cnblogs.com/shu-xiaohao/
 4  * Last modified : 2014-02-08 18:56
 5  * Filename     : uva_1395.cpp
 6  * Description     : 
 7  * ************************************************/
 8 
 9 #include <iostream>
10 #include <cstdio>
11 #include <cstring>
12 #include <cstdlib>
13 #include <cmath>
14 #include <algorithm>
15 #include <queue>
16 #include <stack>
17 #include <vector>
18 #include <set>
19 #include <map>
20 #define MP(a, b) make_pair(a, b)
21 #define PB(a) push_back(a)
22 
23 using namespace std;
24 typedef long long ll;
25 typedef pair<int, int> pii;
26 typedef pair<unsigned int,unsigned int> puu;
27 typedef pair<int, double> pid;
28 typedef pair<ll, int> pli;
29 typedef pair<int, ll> pil;
30 
31 const int INF = 0x3f3f3f3f;
32 const double eps = 1E-6;
33 const int LEN = 102;
34 struct E{
35     int u, v, val;
36 };
37 E edge[LEN*LEN], te[LEN*LEN];
38 int n, m, tag, parent[LEN];
39 
40 bool cmp(E a, E b){return a.val < b.val;}
41 //UFSet
42 void init(){for(int i=0; i<LEN; i++) parent[i] = i;}
43 int Find(int x){return parent[x] == x ? x:parent[x] = Find(parent[x]);}
44 
45 int kruskal(){
46     int cnt = 0, ret = 0;
47     for(int i=0; i<m; i++){
48         if(edge[i].val < tag) continue;
49         int pa = Find(edge[i].u), pb = Find(edge[i].v);
50         if(pa == pb) continue;
51         parent[pa] = pb;
52         cnt ++;
53         ret = max(ret, edge[i].val - tag);
54         if(cnt == n-1) break;
55     }
56     if(cnt == n-1)return ret;
57     else return INF;
58 }
59 
60 int main()
61 {
62 //    freopen("in.txt", "r", stdin);
63     
64     while(scanf("%d%d", &n, &m)!=EOF){
65         if(!n && !m) break;
66         for(int i=0; i<m; i++){
67             scanf("%d%d%d", &edge[i].u, &edge[i].v, &edge[i].val);
68             te[i].u = edge[i].u, te[i].v = edge[i].v, te[i].val = edge[i].val;
69         }
70         int ans = INF;
71         sort(edge, edge+m, cmp);
72         for(int i=0; i<m; i++){
73             tag = te[i].val;
74             init();
75             ans = min(ans, kruskal());
76         }
77         if(ans != INF)printf("%d\n", ans);
78         else printf("-1\n");
79     }
80     return 0;
81 }
View Code

uva 1395(kruskal变形)

原文:http://www.cnblogs.com/shu-xiaohao/p/3540961.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!