ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

算法学习(17):二分图判定

2021-05-17 14:03:22  阅读:110  来源: 互联网

标签:二分 17 int color 算法 maxn 判定 include


二分图判定

怎么判定一个图是否为二分图
从其中一个定点开始,将跟它邻接的点染成与其不同的颜色,最后如果邻接的点有相同颜色,则说明不是二分图,每次用bfs遍历即可。

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
const int maxn=1005;
int color[maxn];//记录节点颜色 
int link[maxn][maxn];//记录连通 
int n,m;//点数,边数 

int dfs(int x,int c){//对x节点进行c染色 ,并向下搜索是否可行 
	color[x]=c;
	for(int i=1;i<=n;i++){
		if(link[x][i]){//判断是否相连 
			if(color[i]==c){//如果已经染色,并且颜色一样,失败,返回0
				return 0;
			}
			if(!color[i]) {//如果没有染色
				if(!dfs(i,-c)) {//向下染色,颜色与原来相反,失败返回0
					return 0;
				}
			}
		}
	}
	//染色成功 
	return 1;
}

void judge() {//判断是否为二分图 
	for(int i=1;i<=n;i++) {
		if(!color[i]) {//如果没有染色,就进行染色
			if(!dfs(i,1)) {
				printf("NO\n");//如果染色失败 输出no 
				return;
			}
		}
	}
	printf("YES\n");//正常遍历结束,输出yes 
}

int main() {
	scanf("%d %d",&n,&m);
	int x,y;
	for(int i=0;i<m;i++) {
		scanf("%d %d",&x,&y);
		link[x][y]=1;
		link[y][x]=1;
	}
	judge();//进行判断
}

标签:二分,17,int,color,算法,maxn,判定,include
来源: https://www.cnblogs.com/xiaoxingaa/p/14776671.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有