华为OD机试真题- 红黑图

该文章描述了一个关于无向图染色的问题,要求没有相邻红色节点。给定图的节点数n和边数m,任务是计算所有满足红黑图条件的染色方案数。通过深度优先搜索(DFS)算法进行求解,并提供了几个示例输入和输出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述:
众所周知红黑树是一种平衡树,它最突出的特性就是不能有两个相邻的红色节点。
那我们定义一个红黑图,也就是一张无向图中,每个节点可能有红黑两种颜色,但我们必须保证没有两个相邻的红色节点。
现在给出一张未染色的图,只能染红黑两色,问总共有多少种染色方案使得它成为一个红黑图。输入描述:
第一行两个数字n m,表示图中有n个节点和m条边。
接下来共计m行,每行两个数字s t,表示一条连接节点s和节点t的边,节点编号为[0,n)。输出描述:
一个数字表示总的染色方案数。补充说明:
0<n<15
0<=m <=n * 30<= s, t < n不保证图连通
保证没有重边和自环

补充说明:0<n<15
0<= m<=n * 30<= s, t < n不保证图连通
保证没有重边和自环 

 示例1

输入:

3 3

0 1

0 2

1 2

输出:4

示例2

输入:

4 3

0 1

1 2

2 3

输出:8

示例3

输入:

4 3

0 1

0 21

2

输出:8

 

#include <iostream>
#include <vector>
#include <queue>
#include <string>
using namespace std;

void dfs(vector<vector<int>>&G,vector<int>&color,int u,int& res)
{
	if (color.size() == u)
	{
		res++;
		return;
	}
	if (color[u] == 0)
	{
		color[u] = 1;
		dfs(G, color, u + 1,res);

		color[u] = 2;
		for (int v : G[u])
		{
			color[v] = 1;
		}
		dfs(G, color, u + 1,res);
	}
	else
		dfs(G, color, u + 1,res);
	color[u] = 0;

}

int main()
{
	int m, n;
	cin >> n >> m;
	vector<vector<int>>G(n);
	vector<int>color(n);
	for (int i = 0; i < m; i++)
	{
		int u, v;
		cin >> u >> v;
		G[u].push_back(v);
		G[u].push_back(u);
	}
	int res = 0;
	dfs(G, color, 0,res);
	cout << res;
	return 0;
}

 

### 华为OD中的房布局题目解析 对于华为OD中涉及的房布局问题,具体的要求是在一排柜上合理布置电箱以确保每个柜旁边都有至少一个电箱。如果无法满足条件,则应返回 `-1`。 #### 题目描述 给定字符串表示的一排房设备布局,其中 `M` 表示柜而 `I` 则代表间隔区域。目标是计算最少需要放置多少个电箱来保障所有柜能够正常运作;若不存在可行方案则输出特殊标记 `-1`[^2]。 #### 解决思路 该类问题可以通过遍历输入串并记录当前最近一次遇到的未被覆盖到的柜位置来进行求解。当发现新的柜时检查之前是否有足够的空间安放新电源装置而不违反规则。最终依据所剩待处理情况决定能否成功完成分配或是宣告失败即返回错误码 `-1`。 ```python def min_electric_boxes(layout): last_uncovered = None electric_box_count = 0 for i, char in enumerate(layout): if char == 'M': if last_uncovered is not None and (i - last_uncovered) > 2: return -1 if last_uncovered is not None or i != len(layout)-1: electric_box_count += 1 last_uncovered = i # Check the final uncovered position if last_uncovered is not None and ((len(layout) - 1 - last_uncovered) > 1): return -1 return electric_box_count if any(c=='M' for c in layout) else 0 ``` 此函数接收一个由字符组成的列表作为参数,这些字符用来描绘整个数据中心内部连续排列着的各种设施。“M”意味着此处存在一台服务器,“I”则是空白处。程序逻辑在于沿着这条线性路径前进的同时维护两个变量:一个是计数器用于统计所需最小数量的电力供应单元数目;另一个是指向最新访问过的尚未得到适当供电支持的服务站索引值。每当触及一个新的服务站点时就会评估从前一处到现在这段距离内是否允许新增加额外的能量源点。最后一步是对末端情况进行特别审查以防遗漏任何潜在违规情形。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值