搜索与图论——染色法判定二分图

一个图是二分图当且仅当这个图中不含奇数环

由于图中没有奇数环,所以染色过程中一定没有矛盾

所以一个二分图一定可以成功被二染色,反之在二染色的过程中出现矛盾的图中一定有奇数环,也就一定不是二分图

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<cstring>

using namespace std;

const int N = 100010, M = 200010;

int n, m;
int h[N], e[M], ne[M], idx;
int color[N]; //color[i]代表i点有没有被染色

void add(int a,int b)
{
    e[idx] = b, ne[idx] = h[a], h[a] = idx ++ ;
}

bool dfs(int u, int c)
{
    color[u] = c; //记录当前点的颜色是c
    for(int i = h[u]; i != -1; i = ne[i])//遍历当前点的邻点
    {
        int j = e[i];
        if(!color[j]) //如果该点没有被染色
        {
            if(!dfs(j, 3 - c)) return false; //有1、2两种颜色,3-1=2,3-2=1,能把邻点染成与u点不同的颜色
        }
        else if(color[j] == c) return false; //如果u的邻点的颜色等于u的颜色
    }
    return true;
}

int main()
{
    cin >> n >> m;
    memset(h, -1, sizeof h);
    while(m -- )
    {
        int a, b;
        cin >> a >> b;
        add(a, b), add(b, a); //无向边
    }
    bool flag = true; //染色过程中是否有矛盾发生
    for(int i = 1; i <= n; i ++ ){
        if(!color[i]) //如果该点没有被染色
        {
            if(!dfs(i, 1)) //如果bfs i点时返回false
            {
                flag = false;
                break;
            }
        }
    }
    if(flag) cout << "Yes" << endl;
    else cout << "No" << endl;
    return 0;
}
相关推荐
小南家的青蛙38 分钟前
LeetCode LCR 085 括号生成
算法·leetcode·职场和发展
jackzhuoa43 分钟前
Rust 异步核心机制剖析:从 Poll 到状态机的底层演化
服务器·前端·算法
夜晚中的人海44 分钟前
【C++】模拟算法习题
c++·算法·哈希算法
花月C1 小时前
算法 - 差分
人工智能·算法·机器学习
拆房老料1 小时前
深入解析提示语言模型校准:从理论算法到任务导向实践
人工智能·算法·语言模型
晨非辰1 小时前
《数据结构风云》递归算法:二叉树遍历的精髓实现
c语言·数据结构·c++·人工智能·算法·leetcode·面试
_dindong4 小时前
牛客101:二叉树
数据结构·c++·笔记·学习·算法
数字化脑洞实验室5 小时前
如何理解不同行业AI决策系统的功能差异?
大数据·人工智能·算法
小白菜又菜8 小时前
Leetcode 3370. Smallest Number With All Set Bits
算法·leetcode·职场和发展
星谷罗殇9 小时前
(七)TRPO 算法 & PPO 算法
算法·机器学习