染色封锁问题

我们只要知道我们一个联通块中的点要么没有被河蟹占着,要么就要有河蟹,这不就是染色问题吗,我们只要取其中的最小值加到我们答案中就行,如果相邻的边颜色一样,就无解

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS
#include<bits/stdc++.h>
using namespace std;

const int N = (int)1e4+5;
const int M = (int)1e5+5;
int n,m;
int e[M*2],ne[M*2],h[N],idx = 0;
int record[N];
int cnt = 0;
int co[N],vis[N];// co是为了记录染色情况,vis是记录是否纳入考虑 
int num1,num2;
int flag = 0;

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

// 我只是疑惑多个联通块的 1 2 怎么算 
void dfs(int node,int fa,int color){
	co[node] = color; vis[node] = 1;
	if(color==1) num1++;
	else num2++;
	for(int i=h[node];i;i=ne[i]){
		int to = e[i];
		if(vis[to]){
			if(co[to]==color&&to!=fa) {
				flag = 1;
				return;
			}
			continue;
		}
		dfs(to,node,abs(color-3));
	}
}

int main(){
	cin >> n >> m;
	for(int i=1;i<=m;i++){
		int u,v;
		cin >> u >> v;
		add(u,v);
		add(v,u);
	}
	int ans = 0;
	for(int i=1;i<=n;i++){
		num1 = 0, num2 = 0;
		if(!vis[i])
		dfs(i,0,1);
		if(flag) {
			cout << "Impossible";  
//				for(int i=1;i<=n;i++){
//		cout <<" i " << i << " co " << co[i] << endl;
//	}
			return 0;
		}
		ans += (min(num1,num2));
	}

	cout << ans;
	return 0;
}
相关推荐
Kuo-Teng2 分钟前
LeetCode 279: Perfect Squares
java·数据结构·算法·leetcode·职场和发展
王哈哈^_^3 分钟前
YOLO11实例分割训练任务——从构建数据集到训练的完整教程
人工智能·深度学习·算法·yolo·目标检测·机器学习·计算机视觉
檐下翻书17337 分钟前
从入门到精通:流程图制作学习路径规划
论文阅读·人工智能·学习·算法·流程图·论文笔记
CoderYanger1 小时前
B.双指针——3194. 最小元素和最大元素的最小平均值
java·开发语言·数据结构·算法·leetcode·职场和发展·1024程序员节
小曹要微笑2 小时前
STM32各系列时钟树详解
c语言·stm32·单片机·嵌入式硬件·算法
前进的李工3 小时前
LeetCode hot100:094 二叉树的中序遍历:从递归到迭代的完整指南
python·算法·leetcode·链表·二叉树
麦麦大数据4 小时前
F049 知识图谱双算法推荐在线学习系统vue+flask+neo4j之BS架构开题论文全源码
学习·算法·知识图谱·推荐算法·开题报告·学习系统·计算机毕业设计展示
兩尛4 小时前
215. 数组中的第K个最大元素
数据结构·算法·排序算法
952364 小时前
数据结构-堆
java·数据结构·学习·算法
吃着火锅x唱着歌5 小时前
LeetCode 面试题 16.24.数对和
算法·leetcode·职场和发展