HDU 3926 图的同构
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3926
题意:给定2个顶点度最大为2的无向图。问你这2个无向图是否同构。
思路:
1.最大度为2.说明这个图可能有多个连通分量,每个连通分量要么是环,要么是链。
2.然后遍历每个连通分量,记录该连通分量的结点个数,以及该连通分量是环还是链。
3.将第一个图按照结点个数排序(若子结点个数相同,则对链先排序)
4.将第二个图按照步骤三排序
5.比较排序后,2个图是否每个元素都相等。若相等,则相似。
关于求链通分量,当然是并查集的一些基本操作了,不过合并的时候应该遵循孩子节点少的合并到孩子节点多的集合中(不然wa),然后就是排序后比较一下就可以了(因为图可能存在环,因此可以先按孩子节点的个数排,然后再按是否存在环排)
#include<time.h>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<iostream>
#include<algorithm>
using namespace std;
const int MAXN=+;
int na,ma,nb,mb,t,Ca=,FaA[MAXN],FaB[MAXN];
struct Node{
int cnt; //连通分量的点数
int Type; //1:是环 0:链
Node(int a=,int b=):cnt(a),Type(b){};
}GroupA[MAXN],GroupB[MAXN]; //图1,图2
void Init(){ //初始化
for(int i=;i<MAXN;i++){
FaA[i]=i; FaB[i]=i;
GroupA[i].cnt=; GroupA[i].Type=;
GroupB[i].cnt=; GroupB[i].Type=;
}
}
int Find(int x,int *Fa){ //并查集
return x==Fa[x]?x:Fa[x]=Find(Fa[x],Fa);
}
void Union(int x,int y,int *Fa,Node *Group){//并查集
int rootx=Find(x,Fa);
int rooty=Find(y,Fa);
if(rootx==rooty){ //存在环
Group[rootx].Type=;
}
else{ //把小的合并到大的树上
if(Group[rootx].cnt>=Group[rooty].cnt){
Group[rootx].cnt+=Group[rooty].cnt;
Fa[rooty]=rootx;
}
else{
Group[rooty].cnt+=Group[rootx].cnt;
Fa[rootx]=rooty;
}
}
}
bool cmp(Node a,Node b){ //排序函数,先按点数排,点数相同则优先排链再到环
if(a.cnt!=b.cnt){
return a.cnt<b.cnt;
}
return a.Type<b.Type;
}
bool solve(){ //比较2个图是否同构
sort(GroupA,GroupA+na+,cmp);
sort(GroupB,GroupB+nb+,cmp);
for(int i=;i<=na;i++){
if((GroupA[i].Type!=GroupB[i].Type)||(GroupA[i].cnt!=GroupB[i].cnt)){
return false;
}
}
return true;
}
int main()
{
scanf("%d",&t);
while(t--){
Init();
scanf("%d %d",&na,&ma);
for(int i=;i<=ma;i++){
int u,v;
scanf("%d%d",&u,&v);
Union(u,v,FaA,GroupA);
}
scanf("%d %d",&nb,&mb);
for(int i=;i<=mb;i++){
int u,v;
scanf("%d %d",&u,&v);
Union(u,v,FaB,GroupB);
}
printf("Case #%d: ",Ca++);
if((na!=nb)||(ma!=mb)){ //点数/边数不匹配
printf("NO\n");
continue;
}
if(solve()){
printf("YES\n");
}
else{
printf("NO\n");
}
}
return ;
}
HDU 3926 图的同构的更多相关文章
- HDU 3926 并查集 图同构简单判断 STL
		给出两个图,问你是不是同构的... 直接通过并查集建图,暴力用SET判断下子节点个数就行了. /** @Date : 2017-09-22 16:13:42 * @FileName: HDU 3926 ... 
- hdu 3926 Hand in Hand 同构图
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3926 In order to get rid of Conan, Kaitou KID disguis ... 
- hdu 3926 Hand in Hand
		http://acm.hdu.edu.cn/showproblem.php?pid=3926 这道题是判断两个图是不是同构相似.只要判断图中环的个数和链的个数,和每个环的节点数和链的节点数是否相等. ... 
- hdu 3926 hands in hands
		https://vjudge.net/problem/HDU-3926 题意:有n个小朋友,他们之间手拉手,但是一只手只能拉一只手或者不拉,现在给出两个图,表示拉手关系,问这两个图是否同构.思路:一开 ... 
- 【转载】图论 500题——主要为hdu/poj/zoj
		转自——http://blog.csdn.net/qwe20060514/article/details/8112550 =============================以下是最小生成树+并 ... 
- hdu图论题目分类
		=============================以下是最小生成树+并查集====================================== [HDU] 1213 How Many ... 
- HDU图论题单
		=============================以下是最小生成树+并查集====================================== [HDU] 1213 How Many ... 
- HDOJ 2111. Saving HDU 贪心 结构体排序
		Saving HDU Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ... 
- 【HDU 3037】Saving Beans Lucas定理模板
		http://acm.hdu.edu.cn/showproblem.php?pid=3037 Lucas定理模板. 现在才写,noip滚粗前兆QAQ #include<cstdio> #i ... 
随机推荐
- ORACLE、MYSQL的JDBC配置
			info.jdbc.driverClassName=oracle.jdbc.driver.OracleDriver info.jdbc.url=jdbc:oracle:thin:@192.168.18 ... 
- ajax+json+Struts2实现list传递实例讲解
			由于学习需要,需要通过ajax来获取后台的List集合里面的值.由于前面没有接触过,所以今天就来研究下了. 一.首先需要下载JSON依赖的jar包.它主要是依赖如下: json-lib-2.2.2-j ... 
- UIView CALayer 的区别
			UIView与CALayer的区别,很详细 研究Core Animation已经有段时间了,关于Core Animation,网上没什么好的介绍.苹果网站上有篇专门的总结性介绍,但是似乎原理性的东西不 ... 
- cocos2d-x 第二篇 HelloWorld的流程
			这篇博客主要是带领大家一起了解整个游戏的执行过程,其中涉及的一些譬如导演,场景,层之类的概念将会在后面讲解. 看main函数的区别: #import <UIKit/UIKit.h> // ... 
- 如何让数据库在每天的某一个时刻自动执行某一个存储过程或者某一个sql语句
			这就要涉及到代理的知识了哦,首先我们要启动代理服务. 
- asp.net Excel数据导入到数据库中
			protected void Btn_Import_Click(object sender, EventArgs e) { bool Result_Import = false; bool Resul ... 
- Qt 扫描进程列表以及获取进程信息
			使用方法: QMap<QString,qint64> app_pid; getAllAppPidList( app_pid ); #include <tlhelp32.h>// ... 
- 网页(HTML)中的特殊字符
			网页(HTML)中的特殊字符 (1)一般来说,在HTML中,一个特殊字符有两种表达方式,一种称作数字参考,一种称作实体参考. 所谓数字参考,就是用数字来表示文档中的特殊字符,通常由前缀“&#” ... 
- Java网络连接之HttpURLConnection 与 HttpClient
			HttpClient使用详解:http://blog.csdn.net/wangpeng047/article/details/19624529 注:HttpURLConnection输出流用ou ... 
- iOS自动更新如何实现
			APP检测更新可以使用两种方法.第一种是和安卓等系统一样,获取自己服务器的APP版本号与已安装的APP版本号比较:第二种是根据已发布到app store上的应用版本号与已安装的APP版本号比较更新.第 ... 
