算法学习笔记(二分图染色)

首先我们需要明确什么是二分图:如果无向图 G = ( V , E ) G = (V, E) G=(V,E)的所有点可以分为两个集合 V 1 、 V 2 V_1、V_2 V1、V2,所有的边都在 V 1 V_1 V1和 V 2 V_2 V2之间,而 V 1 V_1 V1或 V 2 V_2 V2的内部没有边,称 G G G是一个二分图。

直接说结论:如果一个图是二分图,那么它一定没有边数量为奇数的环。

判断一个图是否为二分图,一般用"染色法"进行判断。

用两种颜色对所有点进行染色,要求处在一条边上的两个点的颜色不能相同,染色结束后,如果没有相邻点颜色相同,那就是二分图。

例题;【模板】二分图判定

题目描述

给定一个 n n n点 m m m边的无向图,请判定它是否是一个二分图。

如果是,输出 " Y E S " "YES" "YES",反之输出 " N O " "NO" "NO"。

输入描述

第一行三个整数 n n n, m m m。 ( 1 ≤ n , m ≤ 2 × 1 0 5 ) (1 \leq n,m \leq 2 \times 10^5) (1≤n,m≤2×105)

接下来 m m m行,每行两个整数 x , y x,y x,y表示一条无向边。 ( 1 ≤ x , y ≤ n , x ≠ y ) (1 \leq x,y \leq n,x \not = y) (1≤x,y≤n,x=y)

输出描述

一行输出结果。

输入样例1

复制代码
4 4
1 2 
2 3
3 1
1 4

输出样例1

复制代码
NO

输入样例2

复制代码
4 4
1 2 
2 3
3 4
1 4

输出样例2

复制代码
YES

染色法使用 d f s dfs dfs实现,下边给出带注释代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
using ll = long long;
const int N = 2e5 + 9;

int n, m;
vector<int> g[N];
int col[N];     //存储颜色,-1表示未染色,0、1表示颜色

bool dfs(int x) //染色
{
    for(const auto &y : g[x])       //遍历所有边
    {
        if(col[y] == -1)            //如果没被染色
        {
            col[y] = col[x] ^ 1;    //染上不同颜色

            //下一个节点染不上色就返回flase,将flase传到main函数
            if(!dfs(y)) return false;
        }
        else if(col[y] == col[x]) return false;     //如果已经被染色但是和该节点颜色相同,也返回false
    }
    return true;
}

void solve()
{
    cin >> n >> m;

    //存图
    for(int i = 1; i <= m; ++i)
    {
        int x, y; cin >> x >> y;
        g[x].push_back(y);
        g[y].push_back(x);
    }

    //初始化
    for(int i = 1; i <= n; ++i) col[i] = -1;
    
    int ans = 1;
    for(int i = 1; i <= n; ++i)
    {
        if(col[i] == -1)
        {
            //用与运算只要有一个没染色答案就变成0
            ans &= dfs(i); 
        }
    }

    cout << (ans ? "YES" : "NO") << '\n';
}

int main()
{
    ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
    int _ = 1;
    while(_--) solve();
    return 0;
}

注意初始化!!!注意初始化!!!注意初始化!!!

相关推荐
知识分享小能手1 小时前
React学习教程,从入门到精通, React 属性(Props)语法知识点与案例详解(14)
前端·javascript·vue.js·学习·react.js·vue·react
luckys.one1 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
~|Bernard|2 小时前
在 PyCharm 里怎么“点鼠标”完成指令同样的运行操作
算法·conda
战术摸鱼大师2 小时前
电机控制(四)-级联PID控制器与参数整定(MATLAB&Simulink)
算法·matlab·运动控制·电机控制
Christo33 小时前
TFS-2018《On the convergence of the sparse possibilistic c-means algorithm》
人工智能·算法·机器学习·数据挖掘
汇能感知3 小时前
摄像头模块在运动相机中的特殊应用
经验分享·笔记·科技
阿巴Jun3 小时前
【数学】线性代数知识点总结
笔记·线性代数·矩阵
好家伙VCC4 小时前
数学建模模型 全网最全 数学建模常见算法汇总 含代码分析讲解
大数据·嵌入式硬件·算法·数学建模
茯苓gao4 小时前
STM32G4 速度环开环,电流环闭环 IF模式建模
笔记·stm32·单片机·嵌入式硬件·学习
是誰萆微了承諾4 小时前
【golang学习笔记 gin 】1.2 redis 的使用
笔记·学习·golang