题目链接: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 图的同构的更多相关文章

  1. HDU 3926 并查集 图同构简单判断 STL

    给出两个图,问你是不是同构的... 直接通过并查集建图,暴力用SET判断下子节点个数就行了. /** @Date : 2017-09-22 16:13:42 * @FileName: HDU 3926 ...

  2. hdu 3926 Hand in Hand 同构图

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3926 In order to get rid of Conan, Kaitou KID disguis ...

  3. hdu 3926 Hand in Hand

    http://acm.hdu.edu.cn/showproblem.php?pid=3926 这道题是判断两个图是不是同构相似.只要判断图中环的个数和链的个数,和每个环的节点数和链的节点数是否相等. ...

  4. hdu 3926 hands in hands

    https://vjudge.net/problem/HDU-3926 题意:有n个小朋友,他们之间手拉手,但是一只手只能拉一只手或者不拉,现在给出两个图,表示拉手关系,问这两个图是否同构.思路:一开 ...

  5. 【转载】图论 500题——主要为hdu/poj/zoj

    转自——http://blog.csdn.net/qwe20060514/article/details/8112550 =============================以下是最小生成树+并 ...

  6. hdu图论题目分类

    =============================以下是最小生成树+并查集====================================== [HDU] 1213 How Many ...

  7. HDU图论题单

    =============================以下是最小生成树+并查集====================================== [HDU] 1213 How Many ...

  8. HDOJ 2111. Saving HDU 贪心 结构体排序

    Saving HDU Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  9. 【HDU 3037】Saving Beans Lucas定理模板

    http://acm.hdu.edu.cn/showproblem.php?pid=3037 Lucas定理模板. 现在才写,noip滚粗前兆QAQ #include<cstdio> #i ...

随机推荐

  1. codeforces 567D.One-Dimensional Battle Ships 解题报告

    题目链接:http://codeforces.com/problemset/problem/567/D 题目意思:给出 1 * n 的 field,编号从左至右依次为 1,2,...,n.问射 m 枪 ...

  2. 快速入门GreenDao框架并实现增删改查案例

    大家的项目中不可避免的使用到SQLite,为此我们要花费心思编写一个增删改查框架.而一个好的ORM框架则能够给我们带来极大的方便,今天给大家讲解一个非常火热的ORM-GreenDao. 基本概念 Gr ...

  3. 微信支付官方.net版之坑你没商量

    最近开始弄支付这块,先是支付宝手机网站支付,也是坑了我许久,不过还好,问题不大. 让我们看看微信支付有多少坑 微信商户平台,你们知道么(我前天才知道,别笑我) 登录地址:https://mch.wei ...

  4. osg绘制一个球体

    //By smells2 at Lab 2012-02-21#include <osg/Group>#include <osg/Geode>#include <osg/S ...

  5. NYOJ题目62笨小熊

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAr4AAAK1CAIAAAChInrhAAAgAElEQVR4nO3dO3LjutaG4X8Szj0Qxx

  6. hadoop2.x NameNode 的共享存储实现

    过去几年中 Hadoop 社区涌现过很多的 NameNode 共享存储方案, 比如 shared NAS+NFS.BookKeeper.BackupNode 和 QJM(Quorum Journal ...

  7. linux查看常用操作

    linux下查看文件夹以及文件的大小: df命令可以显示目前所有文件系统的可用空间及使用情形 df -h Filesystem Size Used Avail Use% Mounted on /dev ...

  8. Android View -- setTranslationX

    通过此方法使View位置发生偏移,达到margin的作用却又不改变View的getLeft()的值. 恢复方法是setTranslationX(0),而不是上一次偏移量的相反数. 不过,通过getLo ...

  9. ListView + PopupWindow实现滑动删除

    原文:ListView滑动删除 ,仿腾讯QQ(鸿洋_) 文章实现的功能是:在ListView的Item上从右向左滑时,出现删除按钮,点击删除按钮把Item删除. 看过文章后,感觉没有必要把dispat ...

  10. 阿里云的RDS 查看binlog日志的方法

    按时间点反后台备份的binlog日志从阿里云导出来,然后用mysqlbinlog查看日志内容: # mysqlbinlog -vv --base64-output=decode-rows mysql- ...