POJ 1129 图的染色 暴力

题意:相邻的点着不同的颜色 问一个图最少能用多少种颜色 着色

暴力搜索

虽然没有用四色定理剪枝 但还是介绍一下四色定理

四色定理 最少用4种颜色就能将任意一个图按上述要求染色

#include <cstdio>
#include <iostream>
#include <queue>
#include <cstring>
#include <algorithm>
#define sf scanf
#define pf printf
using namespace std;
const int maxn = 30;
int Adj[maxn][maxn];
int n;
int color[maxn];
bool vis[maxn];
char str[30];
int main(){
    while( sf("%d",&n) && n ){
        memset(Adj,0,sizeof(Adj));
        for(int i = 0;i < n;++i){
            sf("%s",str);
            int u = str[0] - 'A';
            int len = strlen(str);
            for(int j = 2;j < len;++j){
                Adj[u][str[j] - 'A'] = 1;
            }
        }

        memset(color,0,sizeof(color));
        int max_color = 0;
        color[0] = ++max_color;

        for(int i = 1;i < n;++i){
            memset(vis,0,sizeof(vis));
            for(int j = 0;j < n;++j){
                if(i == j) continue;
                if(Adj[i][j]) vis[color[j]] = 1;
            }

            for(int k = 1;k <= max_color;++k){
                if(!vis[k]){
                    color[i] = k;
                    break;
                }
            }
            if(color[i] == 0) color[i] = ++max_color;
        }

        pf("%d channel%s needed.\n",max_color,max_color == 1 ? "" : "s");
    }
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值