洛谷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 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六4 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术5 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize5 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考19 小时前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
美团技术团队1 天前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
用户805533698031 天前
不止三件套:QObject 属性系统全关键字与运行时反射!
c++·qt
To_OC2 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC2 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK2 天前
线段树维护区间 k 次方和
c++·数学·算法·stl