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,然后将所有点遍历一边。

相关推荐
乌萨奇也要立志学C++9 分钟前
【洛谷】递归初阶 三道经典递归算法题(汉诺塔 / 占卜 DIY/FBI 树)详解
数据结构·c++·算法
vyuvyucd27 分钟前
C++引用:高效编程的别名利器
算法
鱼跃鹰飞1 小时前
Leetcode1891:割绳子
数据结构·算法
️停云️1 小时前
【滑动窗口与双指针】不定长滑动窗口
c++·算法·leetcode·剪枝·哈希
码农小韩2 小时前
基于Linux的C++学习——指针
linux·开发语言·c++·学习·算法
wen__xvn2 小时前
第 34 场 蓝桥·算法入门赛·百校联赛
算法
ASD125478acx2 小时前
超声心动图心脏自动检测YOLO11-NetBifPN算法实现与优化
算法
无限进步_3 小时前
【C语言&数据结构】对称二叉树:镜像世界的递归探索
c语言·开发语言·数据结构·c++·git·算法·visual studio
星辞树3 小时前
揭秘阿里 DIN:当深度学习遇上“千物千面”
算法
刘立军3 小时前
如何选择FAISS的索引类型
人工智能·算法·架构