HDU1879--继续畅通工程(最小生成树)

时间:2022-09-08 22:47:00

Problem Description

省*“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可)。现得到城镇道路统计表,表中列出了任意两城镇间修建道路的费用,以及该道路是否已经修通的状态。现请你编写程序,计算出全省畅通需要的最低成本。

Input

测试输入包含若干测试用例。每个测试用例的第1行给出村庄数目N ( 1< N < 100 );随后的 N(N-1)/2 行对应村庄间道路的成本及修建状态,每行给4个正整数,分别是两个村庄的编号(从1编号到N),此两村庄间道路的成本,以及修建状态:1表示已建,0表示未建。
当N为0时输入结束。

Output

每个测试用例的输出占一行,输出全省畅通需要的最低成本。

Sample Input

3
1 2 1 0
1 3 2 0
2 3 4 0
3
1 2 1 0
1 3 2 0
2 3 4 1
3
1 2 1 0
1 3 2 1
2 3 4 1
0

Sample Output

3
1
0

Author

ZJU

Source

浙大计算机研究生复试上机考试-2008年

又是最小生成树。。。。畅通工程==最小生成树

注意这道题目中有一些道路已经修建,而最终的结果是统计修路最少的花费,所以需要判断一下此路是否修建,若没修建,则在最终结果加上此条路的花费

代码

#include<iostream>
#include<algorithm>
#include<stdio.h>
#define MAXN 10000
using namespace std;
int s[MAXN];
int n,m;
struct edge
{
int x;
int y;
int v;
bool t;
}G[MAXN];
int f(int x)
{
if(x==s[x])
return x;
s[x]=f(s[x]);
return s[x];
}
int merg(int a,int b)
{
int x=f(a),y=f(b);
if(x!=y){
s[x]=y;
return 0;
}
return 1;
}
void init()
{
for(int i=0;i<=n;i++){
s[i]=i;
}
}
bool cmp(struct edge a,struct edge b)
{
return a.v<b.v;
}
int main()
{
#ifndef ONLINE_JUDGE
freopen("data.in", "r", stdin);
#endif
int a,b;
int res;
int round;
int flag;
while(scanf("%d",&n),n){
for(int i=0;i<=n;i++){
s[i]=i;
}
res=0;
round=n*(n-1)/2;
for(int i=0;i<round;i++){
scanf("%d%d%d%d",&G[i].x,&G[i].y,&G[i].v,&G[i].t);
if(G[i].t==1)
merg(G[i].x,G[i].y);
}
sort(G,G+round,cmp);
for(int i=0;i<round;i++){
a=f(G[i].x);
b=f(G[i].y);
flag++;
if(a!=b){
s[a]=b;
if(G[i].t==0)
res+=G[i].v;
if(flag==(n-1))
break;
}
}
// cout<<res<<endl;
printf("%d\n",res);
}
return 0;
}

HDU1879--继续畅通工程(最小生成树)的更多相关文章

  1. HDU1879 继续畅通工程 2017-04-12 19&colon;12 50人阅读 评论&lpar;0&rpar; 收藏

    继续畅通工程 Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submis ...

  2. hdu 1879 继续畅通工程 &lpar;最小生成树&rpar;

    继续畅通工程 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Subm ...

  3. HDU1863 畅通工程---&lpar;最小生成树&rpar;

    畅通工程 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  4. hdu 1233 还是畅通工程 最小生成树(prim算法 &plus; kruskal算法)

    还是畅通工程                                                                            Time Limit: 4000/2 ...

  5. hdu1879 继续畅通工程

    http://acm.hdu.edu.cn/showproblem.php?pid=1879 New~ 欢迎“热爱编程”的高考少年——报考杭州电子科技大学计算机学院关于2015年杭电ACM暑期集训队的 ...

  6. HDU 1233 还是畅通工程 &lpar;最小生成树&rpar;

    还是畅通工程 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Subm ...

  7. hdu1863 畅通工程&lpar;最小生成树之prim&rpar;

    Problem Description 省*“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可).经过调查评估,得到的统计表中列出了有可 ...

  8. HDU1879 继续畅通工程 &lpar;并查集&rpar;

    继续畅通工程 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Subm ...

  9. C - 继续畅通工程 最小生成树

    省*“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可).现得到城镇道路统计表,表中列出了任意两城镇间修建道路的费用,以及该道路是否已经 ...

  10. HDU 1233&period;还是畅通工程-最小生成树&lpar;Prime&rpar;

    还是畅通工程 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Subm ...

随机推荐

  1. C&plus;&plus; 系列:编译 boost

    Copyright © 1900-2016, NORYES, All Rights Reserved. http://www.cnblogs.com/noryes/ 欢迎转载,请保留此版权声明. -- ...

  2. 第一篇:Entity Framework 简介

    先从ORM说起吧,很多年前,由于.NET的开源组件不像现在这样发达,更别说一个开源的ORM框架,出于项目需要,以及当时OOP兴起(总不至于,在项目里面全是SQL语句),就自己开始写ORM框架.要开发O ...

  3. if&lpar;username&period;equals&lpar;&OpenCurlyDoubleQuote;zxx”&rpar;&lbrace;&rcub;

    1. if(username.equals(“zxx”){} username可能为NULL,会报空指针错误:改为"zxx".equals(username) 2.  int  x ...

  4. 【STL】全排列生成算法:next&lowbar;permutation

    C++/STL中定义的next_permutation和prev_permutation函数是非常灵活且高效的一种方法,它被广泛的应用于为指定序列生成不同的排列. next_permutation函数 ...

  5. python str &plus; int

    TypeError: cannot concatenate 'str' and 'int' objects 1. print 'Is your secret number " + str(p ...

  6. 依赖注入及AOP简述(四)——&OpenCurlyDoubleQuote;好莱坞原则”和依赖注入框架简介 &period;

    3.2.    “好莱坞原则” 看了前面关于依赖注入概念的描述,我们来提炼出依赖注入的核心思想.如果说传统的组件间耦合方式,例如new.工厂模式等,是一种由开发者主动去构建依赖对象的话,那么依赖注入模 ...

  7. 支付sdk —— 该组件为封装了 微信,支付宝,银联支付

    [精品]  支付组件 简要说明该组件为封装了 微信,支付宝,银联支付, 一键快速集成,几行代码即可集成 微信,支付宝,银联支付. ## 示例: # 测试账号:1.银联支付:提供测试使用卡号.手机号信息 ...

  8. 一个简单的Springmvc应用开发例子

            SpringMVC应用的配置步骤:         1,将所有的jar包导入到lib文件夹下:             jar在spring框架包-->libs-->所有的 ...

  9. 微软发布Xamarin Live Player:Win10可开发iOS

    微软在Build2017大会上发布一款名为Xamarin Live Player的全新工具,可以让PC用户在不使用Mac的前提下测试和调试iOS应用.但是向App Store提交应用时仍然需要Xcod ...

  10. git使用遇到的坑

    把一个完整项目提交到github上步骤以及注意事项 Git的安装就不说了. 第一步:mkdir/cd 我们需要先创建一个本地的版本库(其实也就是一个文件夹). 你可以直接右击新建文件夹,也可以右击打开 ...