二分图的判断(dfs染色法)

如何判断一个图是否为二分图

普通染色法模板

C++ 代码模板如下

思想:先将当前点染色,然后再将该点相连的结点进行染另外一种颜色

下面附上自己画的一张图假设我们从第一个点开始染成红色

后面的染色过程结合下面的代码就很好理解啦

宝图奉上: 请结合代码分析效果会更好

正确情乱:

无法构成二分图的例子如下:

染色过程核心代码

  1. bool dfs(int node, int col)
  2. {
  3. color[node] = col; //染色
  4. for (int i = 0; i < G[node].size(); i++)
  5. {
  6. //如果相邻的顶点同色,就剪掉这一枝,返回false
  7. if (color[G[node][i]] == col)return false;
  8. if (color[G[node][i]] == 0 && !dfs(G[node][i],-col))return false;
  9. }
  10. //如果都染了色返回true
  11. return true;
  12. }

整体代码

  1. #include <iostream>
  2. #include <algorithm>
  3. #include <vector>
  4. using namespace std;
  5. const int inf = 1000;
  6. int V, E;
  7. vector<int> G[inf];
  8. int color[inf] = {0};
  9. bool dfs(int node, int col)
  10. {
  11. color[node] = col; //染色
  12. for (int i = 0; i < G[node].size(); i++)
  13. {
  14. //如果相邻的顶点同色,就剪掉这一枝,返回false
  15. if (color[G[node][i]] == col)return false;
  16. if (color[G[node][i]] == 0 && !dfs(G[node][i],-col))return false;
  17. }
  18. //如果都染了色返回true
  19. return true;
  20. }
  21. void dfsTrave()
  22. {
  23. for (int i = 0; i < V; i++)
  24. {
  25. if (color[i] == 0)
  26. {
  27. if (!dfs(i, 1))
  28. {
  29. cout << "No" << endl;
  30. return;
  31. }
  32. }
  33. }
  34. cout << "Yes" << endl;
  35. }
  36. int main()
  37. {
  38. cin >> V >> E;
  39. int a, b;
  40. for (int i = 0; i < E; i++)
  41. {
  42. cin >> a >> b;
  43. G[a].push_back(b);
  44. G[b].push_back(a);
  45. }
  46. dfsTrave();
  47. system("pause");
  48. return 0;
  49. }

如果大家有什么疑问的话可以加qq向我提出哦,欢迎各位大佬指出问题。

如果你觉得对你有所帮助的话就给我点个赞,点燃我下次写文章的动力吧 _ !

图论 - 二分图的判断(dfs染色法)的更多相关文章

  1. dfs染色法判定二分图

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

  2. hdu 4751 Divide Groups(dfs染色 或 2-sat)

    Problem Description   This year is the 60th anniversary of NJUST, and to make the celebration more c ...

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

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

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

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

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

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

  6. HDU 2444 二分图判断 (BFS染色)+【匈牙利】

    <题目链接> 题目大意: 有N个人,M组互相认识关系互相认识的两人分别为a,b,将所有人划分为两组,使同一组内任何两人互不认识,之后将两个组中互相认识的人安排在一个房间,如果出现单人的情况 ...

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

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

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

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

  9. Codeforces 1144F Graph Without Long Directed Paths DFS染色

    题意: 输入一张有向图,无自回路和重边,判断能否将它变为有向图,使得图中任意一条路径长度都小于2. 如果可以,按照输入的边的顺序输出构造的每条边的方向,构造的边与输入的方向一致就输出1,否则输出0. ...

随机推荐

  1. winform自定义分页控件

    1.控件代码: public partial class PagerControl : UserControl { #region 构造函数 public PagerControl() { Initi ...

  2. IntelliJ IDEA编辑器的使用技巧

    目录 1. 使用技巧 1. 跳转小工具 2. 无处不在的跳转 3. 精准搜索 4. 列操作: 5. live template 6. postfix 7. ALT+ENTER智能提示,代码优化 8. ...

  3. LRU缓存简单实现

    缓存接口定义 /** * 缓存接口 * * @author zhi * */ public interface ICache<K, V> { /** * 添加缓存数据 * * @param ...

  4. Maven 教程(6)— Maven之pom.xml文件简单说明

    原文地址:https://blog.csdn.net/liupeifeng3514/article/details/79543963 通过前面几部分知识,我们对maven已经有了初步的印象,就像Mak ...

  5. Calculation 2

    Calculation 2 Given a positive integer N, your task is to calculate the sum of the positive integers ...

  6. Lab_1:练习5——实现函数调用堆栈跟踪函数

    题目:实现函数调用堆栈跟踪函数 我们需要在lab1中完成kdebug.c中函数print_stackframe的实现,可以通过函数print_stackframe来跟踪函数调用堆栈中记录的返回地址.如 ...

  7. C++17 新特性之 std::optional(上)

    最近在学习 c++ 17 的一些新特性,为了加强记忆和理解,把这些内容作为笔记记录下来,有理解不对的地方请指正,欢迎大家留言交流. 引言 在介绍之前,我们从一个问题出发,C++ 的函数如何返回多个值? ...

  8. lucene字典实现原理(转)

    原文:https://www.cnblogs.com/LBSer/p/4119841.html 1 lucene字典 使用lucene进行查询不可避免都会使用到其提供的字典功能,即根据给定的term找 ...

  9. delphi 格式转换

    TO_CHAR 是把日期或数字转换为字符串 TO_DATE 是把字符串转换为数据库中得日期类型转换函数TO_NUMBER 将字符转化为数字 TO_CHAR 使用TO_CHAR函数处理数字 TO_CHA ...

  10. Java自学-异常处理 自定义异常

    Java 自定义异常 示例 1 : 创建自定义异常 一个英雄攻击另一个英雄的时候,如果发现另一个英雄已经挂了,就会抛出EnemyHeroIsDeadException 创建一个类EnemyHeroIs ...