前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >完全多部图的判断(个人思考)

完全多部图的判断(个人思考)

作者头像
chenjx85
发布2018-09-29 15:24:12
6340
发布2018-09-29 15:24:12
举报

题目描述:

给定一张包含N个点、M条边的无向图,每条边连接两个不同的点,且任意两点间最多只有一条边。对于这样的简单无向图,如果能将所有点划分成若干个集合,使得任意两个同一集合内的点之间没有边相连,任意两个不同集合内的点之间有边相连,则称该图为完全多部图。现在你需要判断给定的图是否为完全多部图。

输入:

第一行输入一个整数T表示数据组数,1<=T<=10。

每组数据格式为:

第一行包含两个整数N和M,1<=N<1000,0<=M<=N(N-1)/2

接下来M行,每行包含两个整数X和Y,表示第X个点和第Y个点之间有一条边,1<=X,Y<=N。

输出:

每组输出占一行,如果给定的图为完全多部图,那么输出Yes,否则输出No。

样例输入:

2 5 7 1 3 1 5 2 3 2 5 3 4 4 5 3 5 4 3 1 2 2 3 3 4

样例输出:

Yes

No

说明:

这道题首先输入一个T,表示有多少组需要判断的数据。

接下来输入节点个数N和边数M,再输入边的两端节点是多少。我们可以把边的信息存储到邻接矩阵中。

先来看一下样例中的反例,1-2,2-3,3-4

如果按照题目中的准则去判断,1跟2之间有边连接,那么1跟2就不能在同一个集合中,而是要分开,构成[[1],[2]]两个集合。

接下来2跟3有边连接,那么2跟3就不能在一个集合中,同时1跟3之间没有边连接,那么集合只能变成[[1,3],[2]]。

接下来3跟4有边连接,4跟2没有边连接,4跟1没有边连接,那么这里就矛盾了,要4和2和1在同一个集合中,但是我们只能1和2之间有边连接的。

所以我们总结一下,我们可以设计两个机制来解决构建集合的问题,一个是开新集合的机制,一个是插入某个已经存在的集合的机制。

这两个机制都要包含检查步骤,确定了目前满足所有条件才可以开新集合或者插入已有集合。

举个样例1的例子,想法如下:

我们首先看点1,1只能在新的集合中,构成大集合[[1]]。

接着看点2,2和1没有边连接,那么2只能和1在同一个集合中,同时检查2能不能和其他的集合中的任意点有边连接。由于这里没有其它集合,所以插入[1]中,构成[[1,2]]。

接着看点3,3和每一个点都有边连接,所以3要开一个新的集合,构成[[1,2],[3]]这个大集合。

接着看点4,4和1没有边连接,那么似乎要把4插入到第一个集合中,构成[[1,2,4],[3]],但在插入前要先检查4跟第一个集合中的所有元素是不是都没有边连接,并且检查4跟其他集合中的元素是不是都有边连接,两个条件中哪一个不能满足,那么就输出No,结束这次样例的检查。

接着看点5,5和每一个点都有边连接,所以5要开一个新的集合,构成[[1,2],[3],[5]]这样的大集合。

时间太晚了,明天再构造代码分享给大家吧。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-09-10 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目描述:
  • 输入:
  • 输出:
  • 样例输入:
  • 样例输出:
  • 说明:
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档