图论---染色法(判断是否为二分图)

O(n+m)

二分图:可以把所有的点划分到两边,使得边只在集合之间,集合内部没有边。

二分图当且仅当图中不含奇数环(边数为奇数条)

cpp 复制代码
#include <iostream>
#include <vector>
#include <cstring>
using namespace std;

const int N = 100010;
int n, m;
vector<int> g[N]; // 邻接表存图
int color[N];

bool dfs(int u, int c) {
    color[u] = c;
    for (int j : g[u]) { // 遍历所有邻接点
        if (!color[j]) {
            if (!dfs(j, 3 - c)) return false;
        }
        else if (color[j] == c) return false;
    }
    return true;
}

int main() {
    cin >> n >> m;
    while (m--) {
        int a, b;
        cin >> a >> b;
        g[a].push_back(b);
        g[b].push_back(a); // 无向图,双向加边
    }
    
    bool flag = true;
    for (int i = 1; i <= n; i++) {
        if (!color[i]) {
            if (!dfs(i, 1)) {
                flag = false;
                break;
            }
        }
    }
    
    if (flag) puts("Yes");
    else puts("No");
    return 0;
}
相关推荐
黑菜钟10 分钟前
代码随想录第53天 | 图论二三题
c++·图论
CoovallyAIHub13 分钟前
华为世界模型来了!30分钟生成272㎡室内场景,虚拟人导航不迷路
深度学习·算法·计算机视觉
西哥写代码14 分钟前
基于dcmtk的dicom工具 第十二章 响应鼠标消息实现图像的调窗、缩放、移动
c++·mfc·dicom·dcmtk·vs2017
熬了夜的程序员16 分钟前
【LeetCode】94. 二叉树的中序遍历
数据结构·算法·leetcode·职场和发展·深度优先
放羊郎17 分钟前
SLAM各类算法特点对比
人工智能·算法·slam·视觉slam·建图·激光slam
熬了夜的程序员21 分钟前
【LeetCode】92. 反转链表 II
数据结构·算法·leetcode·链表·职场和发展·排序算法
Aurorar0rua28 分钟前
C Primer Plus Notes 10
c语言·开发语言·算法
知花实央l34 分钟前
【数字逻辑】24小时数字钟实战!74HC161搭24/60进制计数器+Multisim仿真
算法·测试用例·1024程序员节
兮山与1 小时前
算法20.0
算法
头发还没掉光光1 小时前
Linux多线程之生产消费模型,日志版线程池
linux·运维·开发语言·数据结构·c++