回溯算法----图的m着色问题

给定无向连通图G=(V, E)和m种不同的颜色,用这些颜色为图G的各顶点着色,每个顶点着一种颜色。是否有一种着色法使G中相邻的两个顶点有不同的颜色?

图的m着色问题回溯算法的数据结构

#define NUM 100
int n;				//图的顶点数量
int m;			//可用颜色数量
int a[NUM][NUM];	//图的邻接矩阵
int x[NUM];		//当前的解向量
int sum ;			//已经找到的可m着色的方案数量

回溯算法的实现

//形参t是回溯的深度,从1开始
void BackTrack(int t ){
  int i;
  //到达叶子结点,获得一个着色方案
  if( t > n )  {
    sum ++ ;
    for(i=1; i<=n ;i++)
      printf("%d ",x[i]);
    printf("\n");
  }
  else  //搜索当前扩展结点的m个孩子
    for(i=1; i<=m; i++ ){//尝试每种颜色
      x[t] = i;
      if( Same(t) ) //判断t 和其邻接点的着色方法是否相同
		 BackTrack(t+1);
      x[t] = 0;//回溯的需要,恢复到未着色的状态
    }
}

检查相邻结点的着色是否一样的约束函数

//形参t是回溯的深度
bool Same(int t)
{
  int i;
  for(i=1; i<=n; i++ ) //检查t与所有顶点的邻接关系,包括染色和未染色的。
    if( (a[t][i] == 1) && (x[i] == x[t]))
      return false;
  return true;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值