洛谷P8653:[模板] [蓝桥杯 2017 国 C] 分考场(染色最小色数)

题目描述

n 个人参加某项特殊考试。

为了公平,要求任何两个认识的人不能分在同一个考场。

求最少需要分几个考场才能满足条件。

输入

第一行,一个整数 n(1<n<100),表示参加考试的人数。

第二行,一个整数 m,表示接下来有 m 行数据。

以下 m 行每行的格式为:两个整数 a,b,用空格分开 (1≤a,b≤n) 表示第 a 个人与第 b 个人认识(编号从 1 开始)。

输出

一行一个整数,表示最少分几个考场。

输入输出样例

输入1: 输出1:4

5

8

1 2

1 3

1 4

2 3

2 4

2 5

3 4

4 5

输入2: 输出2:6

5

10

1 2

1 3

1 4

1 5

2 3

2 4

2 5

3 4

3 5

4 5

思路

就是最小色数的模板,这里使用DFS完成。

STEP 1:输入,邻接表存图,计算度数。

STEP 2:定义一个索引数组,对索引数组按度数排序(避免破坏原度数数组)

STEP 3:进行DFS,详见代码。

代码
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n,m,r,c,deg[105],v[105],color[105],ans=INT_MAX;
vector<int>edge[105];
bool cmp(int a,int b)
{
	return deg[a]>deg[b];
}
bool check(int u,int c)
{
	for(int v:edge[u])
	{
		if(color[v]==c)
		{
			return false;
		}
	}
	return true;
}
void dfs(int u,int cn)//v[u] cn:已使用的最大元素书 
{
	if(cn>=ans)//当前色数已不小于最优解
	{
		return;
	}
	if(u>n)
	{
		ans=min(ans,cn); 
		return;
	}
	for(int c=1;c<=cn;c++)//尝试将当前顶点v[u]染成已有的颜色1..cn
	{
		if(check(v[u],c))
		{
			color[v[u]]=c;
			dfs(u+1,cn);
			color[v[u]]=0;
		}
	}
	//都不行,使用新颜色 
	color[v[u]]=cn+1;
	dfs(u+1,cn+1);
	color[v[u]]=0;
}
int main()
{
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	cin>>n>>m;
	for(int i=1;i<=m;i++)
	{
		cin>>r>>c;
		edge[r].push_back(c);
		edge[c].push_back(r);
		deg[r]++,deg[c]++;
	}
	for(int i=1;i<=n;i++)
	{
		v[i]=i;
	}
	sort(v+1,v+1+n,cmp);
	dfs(1,0);
	cout<<ans;
    return 0;
}
运行结果

感谢阅读,我们下期再会。

相关推荐
啊森要自信1 小时前
CANN ops-cv:AI 硬件端视觉算法推理训练的算子性能调优与实战应用详解
人工智能·算法·cann
czy87874751 小时前
深入了解 C++ 中的 `std::bind` 函数
开发语言·c++
我在人间贩卖青春1 小时前
C++之继承的方式
c++·private·public·protected·继承方式
仟濹2 小时前
算法打卡day2 (2026-02-07 周五) | 算法: DFS | 3_卡码网99_计数孤岛_DFS
算法·深度优先
驭渊的小故事2 小时前
简单模板笔记
数据结构·笔记·算法
YuTaoShao2 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展
VT.馒头2 小时前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
goodluckyaa2 小时前
LCR 006. 两数之和 II - 输入有序数组
算法
孤狼warrior2 小时前
YOLO目标检测 一千字解析yolo最初的摸样 模型下载,数据集构建及模型训练代码
人工智能·python·深度学习·算法·yolo·目标检测·目标跟踪
Σίσυφος19003 小时前
PCL法向量估计 之 RANSAC 平面估计法向量
算法·机器学习·平面