题目链接:https://cn.vjudge.net/contest/209473#problem/C

先谈一下二分图相关:

一个图是二分图的充分必要条件:
该图对应无向图的所有回路必定是偶环(构成该环形的边的数量为偶数)。
暂时不证明,后证。

那么怎么判断一个图的回路是奇环还是偶环呢?

交叉染色法。

随机选择一个点,染成红色,把所有跟它相邻的点染成绿色,再由被染色的绿点出发,把相邻的点染成红色……

即对于一个点和他相邻的点(两个点之间有边相连叫做相邻),颜色必定不同,如果相同,那么是奇环。

例如1(红)--2(绿)--3(红)--4(绿)--5(红),颜色是跳跃性相同的,如果是奇环那么一定会出现相邻两点颜色相同的情况。

下面放代码:

bool _dfs(int u){

    int v;
for(int i=;i<g[u].size();i++){
v=g[u][i];
if(color[v]==color[u])return false;
else if(!color[v]){
color[v]=color[u]^;
if(!_dfs(v))return false;
}
}
return true;
}

回归题目。

题目大意:给出一个图,这个图上的每个点的度数都为3,判断这个图可不可以拆分成“爪”字形。也就是所有的边都要用上,并且只用一次,点可以无限使用(至少使用一次),把原图拆分成全为

这种样子的子图。(注意是打散之后!只有这一个样子没有其他连边了!!!)

解题思路:

借助了一下别人的智慧orz。对于题目进行分析,我们能够发现每个点只有两种用法:1、一个“爪”的中心点。2、一个“爪”的旁支。两个条件绝对不可能同时满足,(证明:如果该点满足1,那么从这个点出发的三条边就是延伸边,不可能作为辅助边。如果该点满足2,那么从这个点出发的至少有一条边是辅助边,那么剩下的少于三条边不足以支撑这个点变为爪中心。)

有了这个前提,我们就能很容易地想到二分图两个集合的互斥,那么对于每个点,在和他相连的另一个点上连边,判断一下是否构成二分图就可以了。

(为什么能构成二分图就有解?一个点如果被规定为爪中心,那么它在跟它相连的三个点全为旁支的情况下,是一定能成立的。【关键在于度数全为3】;一个点如果被规定为旁支,那么跟它相连的所有点都必定是爪中心,所以它的三条边也能分配完毕。)

坑点:

图可能不连通。

下面放上0msAC代码:

 #include<stdio.h>
#include<string.h>
#define MAXN 305 int n,g[MAXN][MAXN],color[MAXN]; bool _dfs(int p,int t){ int i;
color[p]=t;
for(i=;i<=n;i++)
if(g[p][i]){
if(color[i]==t)return false;
if(!color[i])
if(!_dfs(i,t^))return false; }
return true;
} int main(){ int x,y,i;
while(true){
scanf("%d",&n);
if(!n)break;
memset(g,,sizeof(g));
memset(color,,sizeof(color));
while(true){
scanf("%d%d",&x,&y);
if(x+y==)break;
g[x][y]=g[y][x]=true;
}
for(i=;i<=n;i++)
if(!color[i])
if(!_dfs(i,))break;
if(i>n)puts("YES");
else puts("NO");
}
return ;
}

【交叉染色法判断二分图】Claw Decomposition UVA - 11396的更多相关文章

  1. poj 2942 求点双联通+二分图判断奇偶环+交叉染色法判断二分图

    http://blog.csdn.net/lyy289065406/article/details/6756821 http://www.cnblogs.com/wuyiqi/archive/2011 ...

  2. hdu 2444(染色法判断二分图+最大匹配)

    The Accomodation of Students Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K ( ...

  3. 染色法判断是否是二分图 hdu2444

    用染色法判断二分图是这样进行的,随便选择一个点, 1.把它染成黑色,然后将它相邻的点染成白色,然后入队列 2.出队列,与这个点相邻的点染成相反的颜色 根据二分图的特性,相同集合内的点颜色是相同的,即 ...

  4. UVA - 10004 Bicoloring(判断二分图——交叉染色法 / 带权并查集)

    d.给定一个图,判断是不是二分图. s.可以交叉染色,就是二分图:否则,不是. 另外,此题中的图是强连通图,即任意两点可达,从而dfs方法从一个点出发就能遍历整个图了. 如果不能保证从一个点出发可以遍 ...

  5. Wrestling Match---hdu5971(2016CCPC大连 染色法判断是否是二分图)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5971 题意:有n个人,编号为1-n, 已知X个人是good,Y个人是bad,m场比赛,每场比赛都有一个 ...

  6. Catch---hdu3478(染色法判断是否含有奇环)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3478 题意:有n个路口,m条街,一小偷某一时刻从路口 s 开始逃跑,下一时刻都跑沿着街跑到另一路口,问 ...

  7. AcWing 860. 染色法判定二分图

    #include <cstring> #include <iostream> #include <algorithm> using namespace std; , ...

  8. 【01染色法判断二分匹配+匈牙利算法求最大匹配】HDU The Accomodation of Students

    http://acm.hdu.edu.cn/showproblem.php?pid=2444 [DFS染色] #include<iostream> #include<cstdio&g ...

  9. dfs染色法判定二分图

    #include<iostream> #include<cstring> using namespace std; ][],color[],n; int dfs(int x,i ...

随机推荐

  1. [LeetCode] 28. Implement strStr() ☆

    Implement strStr(). Returns the index of the first occurrence of needle in haystack, or -1 if needle ...

  2. 【BZOJ】3524: [Poi2014]Couriers

    [算法]主席树 [题解]例题,记录和,数字出现超过一半就递归查找. 主席树见[算法]数据结构 #include<cstdio> #include<algorithm> #inc ...

  3. 【BZOJ】3143: [Hnoi2013]游走 期望+高斯消元

    [题意]给定n个点m条边的无向连通图,每条路径的代价是其编号大小,每个点等概率往周围走,要求给所有边编号,使得从1到n的期望总分最小(求该总分).n<=500. [算法]期望+高斯消元 [题解] ...

  4. NYOJ 409 郁闷的C小加(三) (字符串处理)

    题目链接 描述 聪明的你帮助C小加解决了中缀表达式到后缀表达式的转换(详情请参考"郁闷的C小加(一)"),C小加很高兴.但C小加是个爱思考的人,他又想通过这种方法计算一个表达式的值 ...

  5. python初步学习-python模块之 os

    os os 模块在运维工作中是很常用的一个模块.通过os模块调用系统命令.os模块可以跨平台使用. 在 import os的时候,建议使用import os而非from os import *.这样可 ...

  6. ELK简单使用

    原作者:http://www.cnblogs.com/snidget/p/6269383.html ELK ELK是什么? Elasticsearch LogStash Kibana     1,简单 ...

  7. 构建基于TCP的应用层通信模型

    各层的关系如下图,表述的是两个应用或CS间通信的过程:   通常使用TCP构建应用时,需要考虑传输层的通信协议,以便应用层能够正确识别消息请求.比如,一个请求的内容很长(如传文件),那肯定要分多次发送 ...

  8. 关于函数strtok和strtok_r的使用要点和实现原理

    strtok函数的使用是一个老生常谈的问题了.该函数的作用很大,争议也很大.以下的表述可能与一些资料有区别或者说与你原来的认识有差异,因此,我尽量以实验为证.交代一下实验环境是必要的,winxp+vc ...

  9. Redis 常见面试题

    使用Redis有哪些好处? 速度快 基于内存,避免了磁盘I/O的瓶颈. 单进程单线程,减少了线程上下文切换的开销 利用队列技术将并行访问变为串行访问,消除了传统数据库并发访问控制锁的开销. Redis ...

  10. sad 关于一些html5新属性还需要用https才能支持

    像我昨天在搞一个录音的小东西 在本地正常录音正常播放 但是放到线上环境http环境上就出现了如上的错误 功能都不能正常使用 然后就改成https线上环境  然后就正常了 如上 大家有什么赐教的欢迎留言 ...