码迷,mamicode.com
首页 > 其他好文 > 详细

Uva 10004(二分图的判定)

时间:2015-09-10 19:30:22      阅读:121      评论:0      收藏:0      [点我收藏+]

标签:

这题其实很简单的说,第一次用邻接表来存图= =

首先图的储存结构是结构体+head数组。。。其实head数组保存的

struct node
{
    int v;
    int next;
}V[200*200];


 假设现在有u节点,v表示的是和他邻接的点,next保存的是v对应的编号,head数组保存的是链表的头节点编号。

比如有

1 2

1 3

1 4的点边关系那么V[head[1]].v=4;V[head[2]].v=1,V[head[3]].v=1;

现在讲讲如何判断图是不是二分图,首先对任意没染色的点进行染色,之后判断与其相邻的点若是没染色则染上与其相邻的顶点不同的颜色,若是染过色且与相邻的顶点颜色相同则不是二分图==

判断的过程用dfs来实现

#include<stdio.h>
#include<string.h>
#include<iostream>
#include<algorithm>
using namespace std;
struct node
{
    int v;
    int next;
}V[200*200];
int tol; 
int head[200];
int col[200];
void init()
{
    int tol=0;
    memset(head,-1,sizeof(head));
}
void add(int u,int v)
{
    V[tol].v=v;
    V[tol].next=head[u];
    head[u]=tol++;
}
bool bldfs(int u,int co)
{
    int i,v;
    col[u]=co;
    for(i=head[u];i!=-1;i=V[i].next)
    {
        v=V[i].v;
        if(col[v]==co)
        return false;
        if(col[v]==-1&&!bldfs(v,co^1))
        return false;
    }
    return true;
}
int main()
{
    int n,m;
    while(scanf("%d",&n)!=EOF&&n)
    {
        init();
        int u,v;
        scanf("%d",&m);
        for(int i=0;i<m;i++)
        {
            scanf("%d %d",&u,&v);
            add(u,v);
            add(v,u);
        }
        memset(col,-1,sizeof(col));
        int flag=0;
        for(int i=0;i<n;i++)
        {
            if(col[i]==-1)
            if(!bldfs(i,0))
            {
                flag=1;
                break;
            }
        }
        if(flag==1)
        printf("NOT BICOLORABLE.\n");
        else
        printf("BICOLORABLE.\n");
    }
    return 0;
}

 

Uva 10004(二分图的判定)

标签:

原文地址:http://www.cnblogs.com/NaCl/p/4796279.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!