题目求解的是最小生成树中的最大边:
一次AC代码:
#include <iostream> #include <cstdio> #include <algorithm> using namespace std; class data { public: int from, to, cost; }; data Edge[10005]; int par[2005]; int N, M, num; int cmp(const data& a, const data& b) //从小到大排序 { return a.cost < b.cost; } int finds(int x) //并查集查找函数 { if(x == par[x]) return x; else return par[x] = finds(par[x]); } void join(int x, int y) //并查集合并函数 { x = finds(x); y = finds(y); if(x != y) par[y] = x; } int Kruskal() //用Kruskal算法求解最大费用 { int i, ans = 0; for(i = 0; i <= N; i++) par[i] = i; sort(Edge, Edge + num, cmp); //排序 for(i = 0; i < num; i++) { data e = Edge[i]; if(finds(e.from) != finds(e.to)) //判断是否属于一个并查集 { join(e.from, e.to); if(ans < e.cost) ans = e.cost; } } return ans; } int main() { int a, b, c; while(scanf("%d%d", &N, &M) != EOF) { num = 0; for(int i = 0; i < M; i++) { scanf("%d%d%d", &a, &b, &c); Edge[num].from = a; Edge[num].to = b; Edge[num++].cost = c; } int ans = Kruskal(); printf("%d\n", ans); } return 0; }
原文地址:http://blog.csdn.net/qq_25425023/article/details/45535173