首页 > 其他 > 详细

P1330 封锁阳光大学 (二分图染色)

时间:2020-02-05 20:54:45      阅读:75      评论:0      收藏:0      [点我收藏+]

题目链接

技术分享图片

 

 

题解:

每一个子连通图,对它进行黑白染色,然后取两种染色中的最小值,然后最后汇总。

 

#include <bits/stdc++.h>
# define LL long long
using namespace std;

const int maxn=10000+10;
const int maxm=100000+10;
int n,m;
int col[maxn];
int sum[2];

struct Edge{
    int to,next;
}e[maxm<<1];
int head[maxn];
int en;

void add(int u, int v){
    e[en].next=head[u];
    e[en].to=v;
    head[u]=en;
    ++en;
}

bool dfs(int u, int color){
    if(col[u]!=-1 && col[u]!=color) return false;
    if(col[u]!=-1 && col[u]==color) return true;
    col[u]=color;
    sum[color]++;
    for(int i=head[u];i!=-1;i=e[i].next){
        int v=e[i].to;
        if(!dfs(v,1-color)) return false;
    }
    return true;
}

int main(){
    memset(head,-1,sizeof(head));
    memset(col,-1,sizeof(col));
    scanf("%d %d", &n, &m);
    for(int i=1;i<=m;++i){
        int u,v;
        scanf("%d %d", &u, &v);
        add(u,v);
        add(v,u);
    }
    int res=0;
    for(int i=1;i<=n;++i){
        if(col[i]!=-1) continue;
        sum[0]=0;
        sum[1]=0;
        if(!dfs(i,0)){
            printf("Impossible");
            return 0;
        }
        res+=min(sum[0],sum[1]);
    }
    printf("%d", res);
    return 0;
}

 

P1330 封锁阳光大学 (二分图染色)

原文:https://www.cnblogs.com/FEIIEF/p/12264646.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!