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

本文介绍了如何应用回溯算法解决图的M着色问题,旨在确保图中每条边的两个顶点着不同颜色。首先阐述问题背景,接着详细解释邻接矩阵表示的无向图结构,然后探讨如何判断顶点着色冲突,并最终展示具体的回溯算法源代码。

问题:

给定无向连通图Gm不同的颜色。用这些颜色为图G的各顶点着色,每个顶点着一种颜色。是否有一种着色法使G中每条边的2个顶点着不同颜色,求多少种方法。


邻接矩阵:

如下无向图结构和其邻接矩阵表示,共5个顶点

  

  如何判断第k个顶点的着色是否与其相邻顶点的着色冲突:

判断第1---(k-1)个顶点,若"graph[k][i]==1 && color[i]!=color[k]",即k顶点与其所有相邻顶点的颜色不同即可,可返回false或true来表示。


算法思想:

graph[][]表示邻接矩阵,color[]表示每个顶点的着色,n个顶点,m种颜色,从k=1个顶点开始着色;

若k==n,即说明已找到一种组合,输出color[1]---color[n]; 否则,继续搜索下一个顶点。

若k顶点的着色与其所有相邻顶点的着色不冲突,则继续为下一顶点着色;否则,回溯,测试下一颜色color[i+1];

若所需颜色种类超过设定的颜色数m,则返回;

源代码:





      

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值