acwing搜索与图论(三)染色法

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


const  int N=100010,M=200020;

int n,m;
int h[N],ne[M],e[M],idx;
int color[N];

void add(int a,int b){
	e[idx]=b,ne[idx]=h[a],h[a]=idx++;
	
}


bool dfs(int u,int c)
{
	color[u]=c;
	for(int i=h[u];i!=-1;i=ne[i]){
		int j=e[i];
		if(!color[j]){
			if(!dfs(j,3-c))return false;
			
			
			
		}
		else if(color[j]==c)return false;
		
	}
	
	return true;
}
int main(){
	cin>>n>>m;
	memset(h,-1,sizeof h);
	while(m--){
		int a,b;
		cin>>a>>b;
		add(a,b),add(b,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");
	
	
}

测试数据:

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

其实这个代码挺简单的,存储图的话就两种方式邻接矩阵或者邻接表,邻接表方便dfs深度优先,深度,用深度优先进行判断相邻的两个结点可否染异色,不可以则false,然后将所有点遍历一边。

相关推荐
THMAIL16 小时前
深度学习从入门到精通 - AutoML与神经网络搜索(NAS):自动化模型设计未来
人工智能·python·深度学习·神经网络·算法·机器学习·逻辑回归
金古圣人16 小时前
hot100 滑动窗口
数据结构·c++·算法·leetcode·哈希算法
kebeiovo16 小时前
算法-二叉树的序列化与反序列化
算法
蒹葭玉树16 小时前
【C++上岸】C++常见面试题目--算法篇(第二十期)
c++·算法·面试
JJJJ_iii16 小时前
【左程云算法03】对数器&算法和数据结构大致分类
数据结构·算法·分类
轮到我狗叫了16 小时前
牛客.小红的子串牛客.kotori和抽卡牛客.循环汉诺塔牛客.ruby和薯条
java·开发语言·算法
高山有多高16 小时前
详解文件操作
c语言·开发语言·数据库·c++·算法
乌萨奇也要立志学C++17 小时前
【洛谷】队列相关经典算法题详解:模板队列、机器翻译、海港
算法
YuTaoShao17 小时前
【LeetCode 热题 100】49. 字母异位词分组
算法·leetcode·哈希算法
aliedudu18 小时前
决策树概念与原理
算法·决策树·机器学习