牛客网+紫魔法师+染色问题

这是一篇关于解决仙人掌图染色问题的博客,目标是最小化颜色使用,使得每条边的两个端点颜色不同。代码中使用深度优先搜索进行染色,并检查是否存在奇数环。如果存在奇数环,则需要至少3种颜色,否则2种颜色即可。
摘要由CSDN通过智能技术生成

题目描述 

“サーヴァント、キャスター、Medea。”--紫魔法师

 

给出一棵仙人掌(每条边最多被包含于一个环,无自环,无重边,保证连通),要求用最少的颜色对其顶点染色,满足每条边两个端点的颜色不同,输出最小颜色数即可

输入描述:

第一行包括两个整数n,m,表示顶点数和边数
n <= 100000, m <= 200000
接下来m行每行两个整数u,v,表示u,v之间有一条无向边,保证数据合法

输出描述:

一行一个整数表示最小颜色数

示例1

输入

复制

3 4
1 2
2 3
3 4
1 4

输出

复制

2

这个题目数据很水,我看着有些人的代码是生成随机数的代码,也过了。。。。

不过还是按照题目的要求来吧!毕竟那东西不是自己的真实水平。。。当然我也很菜。。

闲话少说上代码:

#include <bits/stdc++.h>
using namespace std;
vector<int>mp[100005];///数据太大用的vector,不是很熟。。。
int n,m;
bool vis[100005];///标记点有没有访问过
bool col[100005];///颜色
int f = 0;///看看是不是存在奇数的环。
void dfs(int v0)
{
    for(int i=0; i<mp[v0].size(); i++)
    {
       

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值