<hdu - 1863> 畅通工程 并查集和最小生成树问题
本题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1863
行对应村庄间道路的成本,每行给出一对正整数,分别是两个村庄的编号,以及此两村庄间道路的成本(也是正整数)。为简单起见,村庄从1到M编号。当N为0时,全部输入结束,相应的结果不要输出。
解题思路:村庄(支点)之间修公路,给出之间需要的的修路费(权值),如果输入的统计数据不足的话,最后输出的时候输出“?”。这道题既可以用并查集解也可以用最小生成树求解,差不多都可以算是套模板的题,只是最后输出“?”的时候需要点技巧:
最小生成树代码:
#include <iostream>
#include <algorithm>
#define maxn 105
#define INF 999999 using namespace std;
int M, N;///M是村庄数、N是道路数
bool used[maxn];
int cost[maxn][maxn];
int mincost[maxn]; int prim () {
for (int i = ; i <= M; ++i) {
mincost[i] = INF;
used[i] = false;
}
mincost[] = ;
int res = ;
while (true) {
int v = -;
for (int u = ; u <= M; ++u) {
if (!used[u] && (v == - || mincost[u] < mincost[v])) v = u;
}
if (v == -) break;
if (mincost[v] == INF) return INF;///使用这种方法检查输出"?"的情况.
used[v] = true;
res += mincost[v];
for (int u = ; u <= M; ++u) {
mincost[u] = min (mincost[u], cost[v][u]);
}
}
return res;
} int main () {
int a, b, w;
while ((cin >> N) && N ) {
// int flag = 0;
cin >> M;
for (int i = ;i <= M; ++i)
for (int j = ;j <= M; ++j)
cost[i][j] = INF;
for (int i = ; i <= N; ++i) {
cin >> a >> b >> w;
cost[b][a] = cost[a][b] = w;
}
/* for (int i = 1; i <= M; ++i){
for (int j = 1; j <= M; ++j) {
if (cost[i][j] == INF && i != j)
flag = 1;
}//一开始是用这种方法检查单独的点的,(错误)
}*/
int res = prim ();
if (res == INF)
cout << "?" << endl;
else
cout << res << endl;
}
return ;
}
最小生成树(输出“?”技巧):在计算的时候做一个选择的点是否是正无穷的判断(如果一个点是孤立的话,当取到最后的时候会将代码中的v赋值到那个被孤立的点,那个点没有赋值权值,所以就是正无穷)。
并查集代码:
#include<cstdio>
#include<cstring>
#include <iostream>
#include <algorithm>
using namespace std; int pre[];
struct road { //公路的结构体
int x, y, v;
}ad[]; bool cmp(road a, road b) {
return a.v < b.v;
} int find(int x) { //寻找
if(pre[x] != x)
return pre[x] = find(pre[x]);
return pre[x];
} int mix(int x,int y) { //合并
int fx = find(x), fy = find(y);
if(fx == fy)
return ;
pre[fy] = fx;
return ;
} int main() {
int i, j, n, m;
int ans;
int count;
while(~scanf("%d%d",&m,&n)) {
if (m == )
break;
for(j = ; j < m; j++)
scanf("%d%d%d",&ad[j].x ,&ad[j].y,&ad[j].v);
for(i = ; i <= n; i++)
pre[i] = i;
ans = ;
count = ;
sort(ad, ad+m, cmp);
for(i = ; i < m; ++i) {
if(count == n - ) break;
if(mix(ad[i].x, ad[i].y)) {
++ count; /////在这里判断输出"?"的时候
ans = ans + ad[i].v;
}
}
if(count != n - )
printf("?\n");
else
printf("%d\n",ans);
}
return ;
}
并查集(输出“?”技巧):另外定义一个变量,在计算的时候自加,最后判断和“M - 1”(M是村庄的数目)的关系,因为离散的点连成一条线之间的道路条数就是M-1。
欢迎码友评论,一起成长。
<hdu - 1863> 畅通工程 并查集和最小生成树问题的更多相关文章
- hdu 1863 畅通工程 (并查集+最小生成树)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1863 畅通工程 Time Limit: 1000/1000 MS (Java/Others) M ...
- hdu 1863 畅通工程 (并查集 、 kruskal)
畅通工程Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- hdu 1863 畅通工程(Kruskal+并查集)
畅通工程 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- HDU 1863 畅通工程 (并查集)
原题链接:畅通工程 题目分析:典型的并查集模版题,这里就不详细叙述了.对算法本身不太了解的可以参考这篇文章:并查集算法详解 代码如下: #include <iostream> #inclu ...
- 题解报告:hdu 1863 畅通工程
Problem Description 省政府“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可).经过调查评估,得到的统计表中列出了有可 ...
- hdu 1863 - 畅通工程(MST)
畅通工程 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- HDU 1863 畅通工程
畅通工程 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submissi ...
- HDU 1863 畅通工程(Prim算法求解MST)
题目: 省政府“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可).经过调查评估,得到的统计表中列出了有可能建设公路的若干条道路的成本.现 ...
- HDU - 1232 畅通工程-并查集模板
某省调查城镇交通状况,得到现有城镇道路统计表,表中列出了每条道路直接连通的城镇.省政府“畅通工程”的目标是使全省任何两个城镇间都可以实现交通(但不一定有直接的道路相连,只要互相间接通过道路可达即可). ...
随机推荐
- 二分法-C++
对于一个非线性方程f(x)=0求改方程的根,我们的思路可以这么想: 1.根的存在性.若该方程没有根,何必徒劳想法设法去求它的解呢?对于一个方程,我们怎么去找他的根,有连续函数零点定理可知:若有f(a) ...
- [转]OpenSolaris 2009.06, dev setup
Source:http://seriouswebapps.com/opensolaris-200906-dev-setup 1. Snapshot the root zfs pool This all ...
- 基于ReliefF和K-means算法的医学应用实例
基于ReliefF和K-means算法的医学应用实例 数据挖掘方法的提出,让人们有能力最终认识数据的真正价值,即蕴藏在数据中的信息和知识.数据挖掘 (DataMiriing),指的是从大型数据库或数据 ...
- C# 自动提交到百度ping服务
C# 自动提交到百度ping服务 今天无意之间看到百度站长中有这个ping服务(孤陋寡闻呀).... 那什么什么是Ping服务 ping是基于XML_RPC标准协议的更新通告服务,用于博客把内容更新快 ...
- 使用js加载图像和setDataXML()加载数据
使用js加载图像和setDataXML()加载数据 前面一篇对FusionCharts进行了一个简单的介绍,而且建立了我们第一个图形,但是那个是在HTML中使用<OBJECT>和<E ...
- Javascript:由 “鸭子类型” 得出来的推论
Javascript:由 “鸭子类型” 得出来的推论 背景 学动态语言的都知道一句话:“如果它走起来像鸭子,而且叫起来像鸭子,那么它就是鸭子”,Javascript也支持鸭子类型,下文就说说鸭子类型在 ...
- .NET接口和类 反射的差异性发现
1 背景 在项目中使用反射,反射出某类型的所有属性(Property)和对应的属性值.起初为了性能考虑在模块首次加载就反射类型的所有属性并将其存入字典.根据一般的编程规范——基于接口编程,所以首次传入 ...
- CSS样式基础知识
CSS样式基础知识 CSS样式概述 CSS是Cascading Style Sheet 的缩写.译作“层叠样式表单”.是用于(增强)控制网页样式并允许将样式信息与网页内容分离的一种标记性语言. 引用位 ...
- 构建一个真实的应用电子商务SportsStore9
使用MVC4,Ninject,EF,Moq,构建一个真实的应用电子商务SportsStore(九) 实在不好意思,好久没有更新了,我不想找些客观原因来解释,只想请大家见谅!现在我们继续我们的项目,客户 ...
- Arduino 串口篇 Arduino发送二进制 send binary via RS232-to-USB to PC
有用的链接在这里:http://hi.baidu.com/mizuda/item/06b7fdc1d0e45a0ec710b2dd 更加详细的内容请查阅Arduino官方:http://arduino ...