染色法判断二分图
admin
2024-02-12 02:53:20

二分图:

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

染色法:

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

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

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

注意:

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

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

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

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

输出格式:

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

深搜代码:

#include
#include
using namespace std;const int N = 1e6 + 10;
int e[N], ne[N], h[N], idx = 0;
int color[N];
int n, m;void add(int a, int b) {ne[idx] = h[a], e[idx] = b, h[a] = idx++;
}bool dfs(int a, int b) {color[a] = b;for (int i = h[a]; i != -1; i = ne[i]) {if (!color[e[i]]) {if (!dfs(e[i], 3 - b))return false;}else if (color[e[i]] == b)return false;}return true;
}int main() {memset(h, -1, sizeof h);cin >> n >> m;int a, b;while (m--) {cin >> a >> b;add(a, b), add(b, a);}bool flag = true;for (int i = 1; i <= n; i++) {if (!color[i]) {//如果没染色color[i] = 1;if (!dfs(i, 1)){flag = false;break;}}}if (flag)cout << "Yes";else cout << "No";return 0;
}

相关内容

热门资讯

赤水性价比粮食酒推荐:2025... 赤水性价比粮食酒推荐:2025年酱香酒选购全攻略 一、开篇背景与市场痛点 2025年的赤水河流域酒类...
非白酒板块11月19日跌0.3... 证券之星消息,11月19日非白酒板块较上一交易日下跌0.33%,*ST椰岛领跌。当日上证指数报收于3...
以运河文化赋能产业发展|古贝春... 11月17日至19日,以“新质开新局,聚力创未来”为主题的2025年第六届中国白酒黄淮核心产区高质量...
深夜小酌的灵魂搭档:油炝脆骨,... 油炝脆骨是一道充满锅气与烟火气息的家常菜,以其爽脆的口感和浓郁的香辣风味深受许多人喜爱。这道菜的制作...
初中毕业新征程:为什么西点烘焙... 站在初中毕业的人生路口,许多女孩都在思考:哪条路能通往一个既美好又独立的未来?如果有一条道路,能将女...