完美网络

题目描述

完美网络是连通网络的基础上要求去掉网络上任意一条线路,网络仍然是连通网络。求一个连通网络要至少增加多少条边可以成为完美网络。

输入

第一行输入一个数T代表测试数据个数(T<=20)。每个测试数据第一行2个数n,m 分别代表网络基站数和基站间线路数。基站的序号为从1到n。接下来m行两个数代表x,y 代表基站x,y间有一条线路。
(0 < n < m < 10000)

输出

对于每个样例输出最少增加多少线路可以成为完美网络。每行输出一个结果。

示例输入

2
3 1
1 2
3 2
1 2
2 3

示例输出

2

1

完美网络要求每个结点的度数不小于2。

#include <iostream> #include<cstdio> #include<cstdlib> #include<cstring>//memset函数在此头文件中; #include<queue> #include<algorithm>//sort函数在此头文件中; using namespace std; int degree[10001];//计入顶点的度数; int main() {int t;scanf("%d",&t);while(t--){priority_queue<int,vector<int>,greater<int> >q;//优先队列升序;顺序容器适配器int sum=0;//统计应该添加的边数;memset(degree,0,sizeof(degree));//元素度数的初始化;int m,n;scanf("%d%d",&n,&m);while(m--){int v1,v2;scanf("%d%d",&v1,&v2);degree[v1]++;degree[v2]++;//度数}sort(degree+1,degree+n+1);//根据度数来节点升序排列;for(int i=1;i<=n;i++)if(degree[i]<2)//完美网络保证每个节点的度数大于等于二q.push(degree[i]);else//度数升序排列所以要跳出;break;while(q.size()>=2)//保证队列中有两个元素,才能互相加边{int a=q.top();q.pop();int b=q.top();q.pop();a++;b++;sum++;if(a<2)//保证每个节点的度数大于等于二q.push(a);if(b<2)//保证每个节点的度数大于等于二q.push(b);}if(!q.empty())//若队列中仅有一个元素,队列的长度为一时;sum++;printf("%d",sum);if(t!=0)printf("\n");}return 0; }

#include <cstdio>
#include <cstring>
#include <queue>
#include <functional>
#include <algorithm>
using namespace std;int main(int argc, char const *argv[]) {int degree[10001], t, n, m, u, v;scanf("%d", &t);while(t--) {memset(degree, 0, sizeof(degree));scanf("%d %d", &n, &m);while(m--) {scanf("%d %d", &u, &v);degree[u]++;degree[v]++;}sort(degree+1, degree+1+n);priority_queue<int, vector<int>, greater<int> >q;for(int i=1; i<=n; ++i) {if(degree[i] < 2) q.push(degree[i]);	// 加入度小于 2 的点else break;}int cnt = 0;while(q.size() >= 2) {	// 每次取出两个点来连边int v1 = q.top();q.pop();int v2 = q.top();q.pop();v1++;v2++;cnt++;if(v1 < 2) q.push(v1);	// 度仍小于 2,放回队列if(v2 < 2) q.push(v2);}if(!q.empty()) cnt++;printf("%d\n", cnt);}return 0;
}

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

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

相关文章

C++异常处理类与自定义异常处理类

转自&#xff1a;http://blog.csdn.net/makenothing/article/details/43273137 例1&#xff1a;自定义一个继承自excepton的异常类myException C标准中&#xff0c;定义在<stdexcept>中的任何异常类都派生自exception Class&#xff0c;本例也只是简单地由exception继承&…

网络编程概念总结

计算机网路: 计算机网络&#xff0c;是指将地理位置不同的具有独立功能的多台计算机及其外部设备&#xff0c;通过通信线路连接起来&#xff0c;在网络操作系统&#xff0c;网络管理软件及网络通信协议的管理和协调下&#xff0c;实现资源共享和信息传递的计算机系统。 从逻辑…

数据结构实验:连通分量个数

题目描述 在无向图中&#xff0c;如果从顶点vi到顶点vj有路径&#xff0c;则称vi和vj连通。如果图中任意两个顶点之间都连通&#xff0c;则称该图为连通图&#xff0c; 否则&#xff0c;称该图为非连通图&#xff0c;则其中的极大连通子图称为连通分量&#xff0c;这里所谓的极…

如何优化简历

http://mp.weixin.qq.com/s?__bizMzAxMzUzNzYyNA&mid402350492&idx1&sn0e180c05248c845d6ed3e43f5006679e#rd

网络编程之 application/x-www-form-urlencoded MIME编码

编码作用&#xff1a; https://baike.baidu.com/item/魏杰/15581?fraladdin如果我们想要这种表单提交中链接的中文信息不显示出来&#xff0c;那么我们就需要通过MIME编码把中文转换成另外一种编码显示出来,但是这种编码在国内的浏览器中运用的并不多&#xff0c;谷歌浏览器用…

数据结构实验之图论八:欧拉回路

题目描述 在哥尼斯堡的一个公园里&#xff0c;有七座桥将普雷格尔河中两个岛及岛与河岸连接起来。 能否走过这样的七座桥&#xff0c;并且每桥只走一次&#xff1f;瑞士数学家欧拉最终解决了这个问题并由此创立了拓扑学。欧拉通过对七桥问题的研究&#xff0c;不仅圆满地回答…

Linux面试相关

1.TCP/IP 建立连接的过程&#xff1f;&#xff08;3-way shake&#xff09; Client与server建立TCP连接时&#xff1a;首先Client向server发SYN&#xff08;请求&#xff09;&#xff0c;然后server回复&#xff08;应答请求&#xff09;&#xff0c;最后Client回复&#xff0c…

网络编程之 传输层的协议TCP与UDP

传输层协议: TCP和UDP的区别: TCP&#xff1a;面向连接(经历三次握手)、传输可靠(保证数据正确性,保证数据顺序)、用于传输大量数据(流模式)、速度慢&#xff0c;建立连接需要开销较多(时间&#xff0c;系统资源)。 服务端和客户端 UDP&#xff1a;面向非连接、传输不可靠(丢…

n a^o7 !

题目描述 All brave and intelligent fighters, next you will step into a distinctive battleground which is full of sweet and happiness. If you want to win the battle, you must do warm-up according to my instructions, which can make you in the best state prep…

socket阻塞与非阻塞,同步与异步

转自&#xff1a;http://blog.csdn.net/hguisu/article/details/7453390 socket阻塞与非阻塞&#xff0c;同步与异步 作者&#xff1a;huangguisu 1. 概念理解 在进行网络编程时&#xff0c;我们常常见到同步(Sync)/异步(Async)&#xff0c;阻塞(Block)/非阻塞(Unblock)四种调…

网络编程之如何通过URL获取网页代码

java.net 类 URL java.lang.Objectjava.net.URL所有已实现的接口&#xff1a; Serializable public final class URLextends Objectimplements Serializable类 URL 代表一个统一资源定位符&#xff0c;它是指向互联网“资源”的指针。资源可以是简单的文件或目录&#xff0c;…

数据结构实验之图论七:驴友计划

题目描述 做为一个资深驴友&#xff0c;小新有一张珍藏的自驾游线路图&#xff0c;图上详细的标注了全国各个城市之间的高速公路距离和公路收费情况&#xff0c;现在请你编写一个程序&#xff0c;找出一条出发地到目的地之间的最短路径&#xff0c;如果有多条路径最短&#xff…

Windows完成端口(IOCP)

http://blog.csdn.net/piggyxp/article/details/6922277

图结构练习——最小生成树

题目描述 有n个城市&#xff0c;其中有些城市之间可以修建公路&#xff0c;修建不同的公路费用是不同的。现在我们想知道&#xff0c;最少花多少钱修公路可以将所有的城市连在一起&#xff0c;使在任意一城市出发&#xff0c;可以到达其他任意的城市。 输入 输入包含多组数据&a…

Windows 中_T和L

_T("")是一个宏&#xff0c;定义于tchar.h下。[1]&#xfeff; #define _T(x) _ _T(x)   #ifdef _UNICODE #define _ _T(x) L ## x #else /* ndef _UNICODE */ #define _ _T(x) x 他的作用是让你的程序支持Unicode编码 因为Windows使用两种字符集ANSI和UN…

多线程笔记补充之线程通信wait和notify方法以及Lock和Condition接口的使用

线程通信-wait和notify方法介绍: java.lang.Object类提供类两类用于操作线程通信的方法. wait():执行该方法的线程对象释放同步锁,JVM把该线程存放到等待池中,等待其他的线程唤醒该线程. notify:执行该方法的线程唤醒在等待池中等待的任意一个线程,把线程转到锁池中等待. notif…

数据结构实验之图论六:村村通公路

题目描述 当前农村公路建设正如火如荼的展开&#xff0c;某乡镇政府决定实现村村通公路&#xff0c;工程师现有各个村落之间的原始道路统计数据表&#xff0c;表中列出了各村之间可以建设公路的若干条道路的成本&#xff0c;你的任务是根据给出的数据表&#xff0c;求使得每个村…

技术人生“白天求生存,晚上谋发展”

白天求生存&#xff0c;晚上谋发展 这句话最近在团队经常有人说&#xff0c;其实我也深有体会&#xff0c;因为我看到的技术牛人他们背后肯定有一段很长时间的艰苦时光&#xff0c;可能是3年&#xff0c;也可能是8年&#xff0c;也可能一直还在坚持。 其实我们周围大部份人有一…

CRT

当C Runtime函数库于20世纪70年代产生出来时&#xff0c;PC的内存容量还很小,多任务是个新奇观念&#xff0c;更别提什么多线程了。因此以当时产品为基础所演化的C Runtime函数库在多线程&#xff08;multithreaded&#xff09;的表现上有严重问题&#xff0c;无法被多线程程序…