• 染色法判断二分图


    二分图

    二分图又称作二部图,指的是图中的点可以分割成两个点集,每个点集中的点之间没有边将他们相连。一个图是二分图,那么他必然不含奇数环。

    染色法:

    先随意取出一个未染色的点,然后对其染色,把其相邻的点染上其他颜色(二染色),如果所有点都染完也不存在冲突的话,那么就是二分图。

    染色的过程就是遍历所有点的过程,所以深搜和宽搜都可以。

    二染色技巧:1代表一种颜色,2代表一种颜色,每次用3减去当前颜色就是另一种颜色了。

    注意:

    1.二分图是无向图,一个边要在邻接矩阵中存储两次。

    2.二分图不一定是联通的,分成多个二分集合也是可以的。

    输入格式:
    第一行包含两个整数 n 和 m。

    接下来 m 行,每行包含两个整数 u 和 v,表示点 u 和点 v 之间存在一条边。

    输出格式:

    如果给定图是二分图,则输出Yes,否则输出No。

    深搜代码:

    1. #include
    2. #include
    3. using namespace std;
    4. const int N = 1e6 + 10;
    5. int e[N], ne[N], h[N], idx = 0;
    6. int color[N];
    7. int n, m;
    8. void add(int a, int b) {
    9. ne[idx] = h[a], e[idx] = b, h[a] = idx++;
    10. }
    11. bool dfs(int a, int b) {
    12. color[a] = b;
    13. for (int i = h[a]; i != -1; i = ne[i]) {
    14. if (!color[e[i]]) {
    15. if (!dfs(e[i], 3 - b))
    16. return false;
    17. }
    18. else if (color[e[i]] == b)return false;
    19. }
    20. return true;
    21. }
    22. int main() {
    23. memset(h, -1, sizeof h);
    24. cin >> n >> m;
    25. int a, b;
    26. while (m--) {
    27. cin >> a >> b;
    28. add(a, b), add(b, a);
    29. }
    30. bool flag = true;
    31. for (int i = 1; i <= n; i++) {
    32. if (!color[i]) {//如果没染色
    33. color[i] = 1;
    34. if (!dfs(i, 1)){flag = false;break;}
    35. }
    36. }
    37. if (flag)cout << "Yes";
    38. else cout << "No";
    39. return 0;
    40. }

  • 相关阅读:
    每日一练--IT冷知识&C/C++--第三天
    Github 2024-06-20 Go开源项目日报 Top10
    关于LWIP的一点记录(二)
    Docker面试整理-如何进行Docker镜像的构建和发布?
    STM32F103实现激光测距传感器测距WT-VL53L0 L1
    在ubuntu上搭建nexus私有仓库[失败草稿]
    nginx学习(1)
    查看windows后台进程命令行参数
    架构与思维:互联网高性能Web架构
    Linux的用户管理
  • 原文地址:https://blog.csdn.net/weixin_56265979/article/details/128024715