四色原理c++实现

验证四色原理
描述

验证任何一个平面存在一种着色方案,使得相连的区域颜色不同,且颜色种类不大于4;
在这里插入图片描述
输入

第一行输入n。第2n+1行:每行表示1n个省,相邻的省用1表示(本身不与本身相邻)。

输出

输出每种可以填色的方式

输入样例 1

7
0 1 0 0 0 0 1
1 0 1 1 1 1 1
0 1 0 1 0 0 0
0 1 1 0 1 0 0
0 1 0 1 0 1 0
0 1 0 0 1 0 1
1 1 0 0 0 1 0
输出样例 1

1 2 1 3 1 3 4 (这是其中的一种,并按字典顺序输出)

#include <bits/stdc++.h>

using namespace std;

int has[25];
int c[25][25];
int n ;
void input ()
{
	
	cin >> n ;
	for(int i = 1 ; i<= n ; i++)  
	    for(int j = 1 ; j<= n ; j++)
	        cin >> c[i][j];
}
bool pan(int d , int co)
{
	for(int a = 1 ; a <= d-1 ; a++ )                  // 查到 n-1 (不能搜到自己本身) 
		if(c[d][a] == 1 &&has[a] == co )
			return 0;                               // 空格 划开层次 
	return 1; 
}
int dfs(int dep )
{
	if(dep>n)                                    //逻辑表达式要对  (dep > n ) || (dep == n+1) 
	{
		for(int i = 1 ; i <= n ; i++)
			cout << has[i] << " ";
		cout<<endl;
		exit(0);
	}
	else
	   {

		for(int co = 1 ; co <= 4 ; co++)
		{
			has[dep] = co ;                    //要先赋值才能判断 
			if(pan(dep,co)) 
				dfs(dep+1);
	    }
	   }  
}
int main()
{
	input ();
	dfs(1);
	return 0 ;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值