畅通工程 HDU - 1863

省政府“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可)。经过调查评估,得到的统计表中列出了有可能建设公路的若干条道路的成本。现请你编写程序,计算出全省畅通需要的最低成本。 

Input测试输入包含若干测试用例。每个测试用例的第1行给出评估的道路条数 N、村庄数目M ( < 100 );随后的 N 
行对应村庄间道路的成本,每行给出一对正整数,分别是两个村庄的编号,以及此两村庄间道路的成本(也是正整数)。为简单起见,村庄从1到M编号。当N为0时,全部输入结束,相应的结果不要输出。 
Output对每个测试用例,在1行里输出全省畅通需要的最低成本。若统计数据不足以保证畅通,则输出“?”。 
Sample Input

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

Sample Output

3
?


这题是也是一个并查集。略微加了点东西,适用于并查集入门
 1 #include<iostream>
 2 #include<stdio.h>
 3 #include<cstring>
 4 #include<algorithm>
 5 using namespace std;
 6 #define maxn 1010
 7 int a[maxn];
 8 struct node {
 9     int x,y,cost;
10 } qu[maxn];
11 int find(int r) {
12     while(r!=a[r]) r=a[r];
13     return r;
14 }
15 int cmp(node a,node b) {
16     return a.cost<b.cost;
17 }
18 int main() {
19     int n,m;
20     while(scanf("%d%d",&n,&m)!=EOF) {
21         if (n==0) break;
22         for (int i=1 ; i<=m ; i++) a[i]=i;
23         for (int i=0 ; i<n ; i++) {
24             scanf("%d%d%d",&qu[i].x,&qu[i].y,&qu[i].cost);
25         }
26         sort(qu,qu+n,cmp);
27         int ans=0;
28         node b;
29         for (int i=0 ; i<n ; i++) {
30             b=qu[i];
31             int nx=find(b.x);
32             int ny=find(b.y);
33             if (nx!=ny) {
34                 a[nx]=ny;
35                 ans+=b.cost;
36             }
37         }
38         int flag=1;
39         for (int i=1 ; i<=m ; i++) {
40             if (find(1)!=find(i)) {
41                 flag=0;
42                 break;
43             }
44         }
45         if (flag) printf("%d\n",ans);
46         else printf("?\n");
47     }
48     return 0;
49 }

 

 

转载于:https://www.cnblogs.com/qldabiaoge/p/8507641.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/267519.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SoftReference和WeakReference

Java2增强了内存管理功能&#xff0c; 增加了一个java.lang.ref包&#xff0c;其中定义了三种引用类。这三种引用类分别为SoftReference、WeakReference和PhantomReference.通过使用这些引用类&#xff0c;程序员可以在一定程度与GC进行交互&#xff0c;以便改善GC的工作效率。…

docker ubuntu 文件同步_Docker 的数据管理--Docker从入门到精通摘记

Docker 数据管理用户在使用 Docker 的过程中&#xff0c;‍‍往往需要能够查看容器内应用产生的数据&#xff0c;‍‍或者说‍‍需要把容器内的数据进行备份&#xff0c;‍‍再或者说‍‍多个容器之间需要进行数据的共享&#xff0c;‍‍那么这些就必然涉及到容器的数据管理操作…

杂项:UN-APP

ylbtech-杂项&#xff1a;APP1.返回顶部 2.返回顶部3.返回顶部4.返回顶部5.返回顶部 6.返回顶部7.返回顶部8.返回顶部9.返回顶部 10.返回顶部11.返回顶部12.返回顶部13.返回顶部14.返回顶部15.返回顶部 1、https://baike.baidu.com/item/%E6%89%8B%E6%9C%BA%E8%BD%AF%E4%BB%B62…

ubuntu上网慢的问题

2019独角兽企业重金招聘Python工程师标准>>> 测试用的是ubuntu11.10&#xff0c;教育网宽带&#xff0c;静态IP&#xff0c;无路由 如果用的是路由的应该不会很慢吧&#xff0c;路由自带DNS缓存功能的,本地DNS缓存就没有必要了 建立本地DNS缓存: (1) 安装DNS缓存软件…

c include 多层目录_Rsync 秒杀一切备份工具,你能手动屏蔽某些目录吗?

转自&#xff1a;高效运维引言Rsync 是一种快速且通用的命令行实用程序&#xff0c;可通过远程shell在两个位置之间同步文件和文件夹。使用 Rsync&#xff0c;可以镜像数据&#xff0c;创建增量备份&#xff0c;并在系统之间复制文件。复制数据时&#xff0c;你可能要根据文件名…

第2章 一切都是对象

第2章一切都是对象 对象的定义(类型)、创建、存储、操纵、销毁、组成&#xff0c;引用(基本变量名)的初始化 2.1 用引用操纵对象 编程语言操纵内存中元素的方式&#xff1a; C、C&#xff1a;基于特殊语法的间接表示—指针 Java&#xff1a;操纵对象引用 ->对象 创建引用…

Lucene学习笔记(1)

Lucene学习笔记可以搜索文本文件&#xff0c;理论上可以搜索任何类型的数据。只要先把数据转化为文本&#xff0c;就可以对数据进行索引和搜索。使用了反向索引的机制&#xff0c;维护一个词/短语的表&#xff0c;对于每个词和短语都有一个链表描述有哪些文档包含这个词和短语。…

android 录音原始文件_5分钟短文 | Android证书生成,签名,验证,虽然难,但学一次就够了!...

引言从Android演进开始&#xff0c;APK签名就已经成为Android的一部分&#xff0c;并且android要求所有Apks都必须先签名&#xff0c;然后才能将其安装在设备上。关于如何生成密钥以及如何签名的文章很多。一个Apk&#xff0c;但我们将从安全角度进行研究。在对Apk文件进行反编…

WCF跨域 这可能是由于试图以跨域方式访问服务而又没有正确的跨域策略,或策略不适用于 SOAP...

尝试向 URI“http://localhost:8001/AccountService.svc”发出请求时出错。这可能是由于试图以跨域方式访问服务而又没有正确的跨域策略&#xff0c;或策略不适用于 SOAP 服务。您可能需要与该服务的所有者联系&#xff0c;以发布跨域策略文件并确保该文件允许发送 SOAP 相关的…

【XSY2472】string KMP 期望DP

题目大意 给定一个由且仅由字符H&#xff0c;T构成的字符串\(S\)。 ​  给定一个最初为空的字符串\(T\) &#xff0c;每次随机地在\(T\)的末尾添加H或者T。 问当\(S\)为\(T\)的后缀时&#xff0c;在末尾添加字符的期望次数。 对\({10}^97\)取模 题解 设\(f_i\)为从\(i-1\)匹配…

go语言api源码中文版_Go语言学习——sync.map源码剖析

1.简介 最近看了下Sync包&#xff0c;详读了sync.map源码&#xff0c;感觉源码实现还是比较巧妙的&#xff0c;有不少可以学习的地方&#xff1b;在讲源码前&#xff0c;先看下sync.map的"历史"&#xff0c;从网上搜资料&#xff0c;sync.map是Go语言在1.9版本才引入…

JDK自带的log-java.util.logging

配置: 默认情况下&#xff0c;每个 FileHandler 都是使用以下 LogManager 配置属性执行初始化的。如果没有定义属性&#xff08;或者属性具有非法值&#xff09;&#xff0c;则使用指定的默认值。 java.util.logging.FileHandler.level 为 Handler 指定默认的级别&#xff08;默…

js实现添加className

obj.className ; //设置为新的obj.className ;//在原来的后面加这个obj.classList.add(" "); //与第一个等价 <style>#side_btn {width: 15%;left: 0;bottom: 5%;}#side_nav {width: 25%;left: -34%;top: 15%;transition: left 1s;text-align: center;}.nav_…

怎么成为日上会员直邮_18个日上直邮问题汇总,可以参考一下哦

前段时间发的日上直邮的微头条和视频&#xff0c;很多朋友遇到一些不明白的地方&#xff0c;我把问题汇总了一下&#xff0c;统一回答一下哦其实因为疫情&#xff0c;很多免税店都在做活动&#xff0c;活动方式不太一样&#xff0c;有好多种&#xff0c;我跟大家分享的只是其中…

IT网址大全

图像处理 [素材]   在线作图[素材]   思缘设计论坛[素材]   ps联盟[素材]   ps学习网[素材]   ps教程论坛[素材]   ps爱好者[素材]   46ps[素材]   勤学网[素材]   艺术字体转换器[模板]   视达千图[模板]   千图网[模板]   千库网[模板]   包图网[模板]   摄图网…

python中sort返回值_Python函数你真的都学会了吗?来看看这篇Python高阶函数!

二、高阶函数高级函数, 英文叫 Higher-order Function.那么什么是高阶函数呢?在说明什么是高阶函数之前, 我们需要对函数再做进一步的理解!2.1 函数的本质函数的本质是什么&#xff1f;函数和函数名到底是一种什么关系&#xff1f;在python中&#xff0c;一切皆对象&#xff0…

拿什么衡量能力?!

众所周知&#xff0c;计算机技术属于高科技的范畴&#xff0c;但不能说所有和计算机沾边的东西都可以称之为高科技&#xff0c;笔者前几天经历了一次面试&#xff0c;也许对于有的朋友来说&#xff0c;这样的经历司空见惯&#xff0c;但是我还是想一吐为快。 本人不才&#xff…

基于数据库的事务消息解决分布式事务方案

转载请注明出处&#xff1a;http://www.cnblogs.com/lizo/p/8516502.html 概述 当单库已不能支撑当前业务的时候&#xff0c;我们往往都考虑进行分库&#xff08;横向拆分或者纵向拆分&#xff09;。但分库有个无法回避的问题&#xff0c;就是事务问题。网上有很多分布式事务解…

websocket 发送给前端一个对象_前端WebSocket封装

场景1: 只有单个长链接&#xff0c;不要求保活class WebSocketClass {constructor() {this.instance null;this.connect();}static getInstance() {if (!this.instance) {this.instance new WebSocketClass();}return this.instance;}connect() {this.ws new WebSocket(ws:/…

POJ1683 Puzzlestan ——Floyd传递闭包+Dfs

好久没写Dfs了&#xff0c;拿来练手。 WA了一次&#xff0c;没有判断中间的情况…… 解法&#xff1a;先用Floyd传递闭包处理哪些点一定要在一起、哪些点一定不能在一起&#xff0c;六重循环。 然后深搜&#xff0c;res[i][j]表示1,i这个物品在j这一行的匹配物品列编号。 没有最…