Kruskal算法-HDU1863畅通工程】的更多相关文章

链接 [http://acm.hdu.edu.cn/showproblem.php?pid=1863] 题意 Problem Description 省政府"畅通工程"的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可).经过调查评估,得到的统计表中列出了有可能建设公路的若干条道路的成本.现请你编写程序,计算出全省畅通需要的最低成本. Input 测试输入包含若干测试用例.每个测试用例的第1行给出评估的道路条数 N.村庄数目M ( &l…
最小生成树 通俗解释:一个连通图,可将这个连通图删减任意条边,仍然保持连通图的状态并且所有边权值加起来的总和使其达到最小.这就是最小生成树 可以参考下图,便于理解 原来的图: 最小生成树(蓝色线): 最小生成树主要有prim和kruskal两种算法 其中prim可以用优先队列实现,kruskal使用并查集来实现 两种算法针对于不同的数据规模有不同的效率,根据不同的题目可以选择相应的算法. 经典最小生成树算法应用的案例如HDU-1863这个问题 概述: 省政府"畅通工程"的目标是使全省任…
畅通工程 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 27972    Accepted Submission(s): 12279 Problem Description 省政府“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可).经过调查评估,得到的统计表中列出了有可能建…
畅通工程 Time Limit : 1000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submission(s) : 65   Accepted Submission(s) : 40 Font: Times New Roman | Verdana | Georgia Font Size: ← → Problem Description 省政府"畅通工程"的目标是使全省任何两个村庄间都可以实…
畅通工程 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 39468    Accepted Submission(s): 17635 Problem Description 省政府"畅通工程"的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可).经过调查评估,得到的统计表中列…
Problem Description 省政府“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可).经过调查评估,得到的统计表中列出了有可能建设公路的若干条道路的成本.现请你编写程序,计算出全省畅通需要的最低成本.   Input 测试输入包含若干测试用例.每个测试用例的第1行给出评估的道路条数 N.村庄数目M ( < 100 ):随后的 N 行对应村庄间道路的成本,每行给出一对正整数,分别是两个村庄的编号,以及此两村庄间道路的成本(…
题目传送门 /* 此题为:HDOJ 1233 + HDOJ 1232 */ #include <cstdio> #include <algorithm> #include <cstring> #include <cmath> using namespace std; + ; int pre[MAX_N]; int tot; int sum; struct NODE { int x, y; int len; }node[MAX_N]; int find(int…
#include<cstdio> #include<algorithm> #define MAX 105 struct edge { int from,to; long long cost; }lm[MAX*MAX]; int N,M,father[MAX],i; bool cmp(edge a,edge b) { return a.cost<b.cost; } void init() { for(int i=1;i<=N;i++) father[i]=i; } int…
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1863 题目大意: 中文题,求MST权值,如果不连通,输出? 解题思路: 这道题帮我找出了之前模板中的一点小问题. 原来prim模板是迭代n次,实际是只需要迭代n-1次就求出了MST,由于有一个条件判断,所以迭代n次也无所谓.这道题在prim模板上加上判断连通的操作,如果某一次找不到为加入MST的最小边,说明图不连通.所以此处只能迭代n-1次,多迭代的话,会造成错误判断. #include<bits…
#include <iostream> #include <cstdio> #include <algorithm> #define N 110 #define M 5000 using namespace std; int n, m, u[M], v[M], w[M], r[M], p[N]; bool cmp(int i, int j){ return w[i]<w[j]; } int f(int x){ return p[x] == x ? x : p[x]…