图论基础---二分图判定(涂色问题)

利用图的特性,以及dfs对整个图进行遍历,完成整个涂色过程

#include<cstdio>
#include<algorithm>
#include<vector>
using namespace std;
const int MAX_i = 10000+1;
int V, E;//V表示顶点数,E表示边的数量
int color[MAX_i];//表示节点颜色的数组,其中1表示一种颜色,-1是另一种颜色,初始化数值是0
vector<int> G[MAX_i];//存储图的信息
bool dfs(int v, int c);//深度优先搜索遍历图的每一个节点
void sovle();
int main(void)
{
    scanf("%d %d", &V, &E);
    for(int i = 0; i < E; i++)
    {
        int f, t;
        scanf("%d %d", &f, &t);
        G[f].push_back(t);
        G[t].push_back(f);//无向图
    }
    sovle();
    return 0;
}
void sovle()
{
    for(int i = 0; i < V; i++)
    {
        if(color[i] == 0)//从没有涂色的节点开始深度优先搜索
        {
            if(!dfs(i, 1))
            {
                printf("no");
                return ;    
            }    
        }    
    }
    printf("yes");    
}
bool dfs(int v, int c)
{
    color[v] = c;//将节点v置为一种颜色
    for(int i = 0; i < G[v].size(); i++)
    {
        if(color[G[v][i]] == c)//如果和节点v相连的其他节点也是同样的颜色,说明涂色不能完成
        {
            return false;
        }
        if((color[G[v][i]] == 0) && (!dfs(G[v][i], -c)))//如果相邻节点未涂色,但涂色后结果非法,也说明涂色无法完成
        {
            return false;
        }
    }
    return true;//涂色完成
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值