zoukankan      html  css  js  c++  java
  • 图论——二分图1:二分图以及判定

    图,有有向图,无向图,稠密图,简单图······

    算法,有贪心法,二分法,模拟法,倍增法······

    那,二分图是啥?

    二分法+有向图?

    于是,我查了许多资料,才对它有一定了解。

    二分图:二分图,是图论中的一种特殊模型,设G=(V,E)是一个无向图,如果顶点V可分割为两个互不相交的子集(A,B),并且同一集合中不同的两点没有边相连。

    这就是二分图。

    举个栗子吧:

    这是不是二分图?

    反正我第一次看觉得不是

    其实,是的,他是二分图,尽管看上去是连着的。

    若我们将图中的一些边转一下,变成:

    这就是一个明显的二分图。

    集合A与B中的点互不相连。

    因此,在手动判定二分图时学会转边!

    辣魔,二分图要用计算机判定怎么实现?

    数竞大佬:简单!

    !!!染色大法!!!

    有没有熟悉的感觉

    0表示还未访问,1表示在集合A中,2表示在集合B中。

    col(color)储存颜色。

    初始化为0.

    上代码:

     其实是模板

    可以记忆。

     1 vector <int> v[N];
     2 void dfs(int x,int y){
     3   col[x]=y;            
     4   for (int i=0; i<v[x].size(); i++) {
     5      if (!col[v[x][i]]) dfs(v[x][i],3-y);
     6      if (col[v[x][i]]==col[x]) FLAG=true;      //产生了冲突
     7   }
     8 }
     9 for (i=1; i<=n; i++) col[i]=0;    //初始化
    10 for (i=1; i<=n; i++) if (!col[i]) dfs(i,1);    //dfs染色
    11 if (FLAG) cout<<"NO"; else cout<<"YES";

    下一章我们将讲到二分图的匹配,我们明天见。

  • 相关阅读:
    如何把样例从文件中输入程序
    蓝桥杯--高僧斗法(变形尼姆博弈)
    tensorflow笔记(北大网课实战)
    深度学习笔记
    尼姆博弈
    并查集
    蓝桥杯算法训练--指针
    NumPy笔记:均匀分布与正态分布
    NumPy学习:创建ndarray数组(linespace,arange,uniform,normal)
    NumPy笔记:数组去重
  • 原文地址:https://www.cnblogs.com/sillyben/p/9905456.html
Copyright © 2011-2022 走看看