谁能帮我解释下这段代码

yangboufo 2009-11-28 11:09:49
是采用暴搜的方法,关于四色图问题,能详细的解释下吗?

#include<iostream>

using namespace std;

int colour[40],cnt,n;

int map[100][100];

int judge(int deep,int k)
{
for( int j = 0; j < n;j++)
if(map[deep][j] && colour[j] == k)
return 0;
return 1;
}

int solve(int deep , int k )
{
if(deep == n )
return 1;
else
{
for( int i = 0 ;i < k;i++)
{
if( judge(deep,i) )
{
colour[deep] = i;
if(solve(deep + 1 , k))
return 1;
}
}
}
return 0;
}
int main()
{
while(cin>>n && n)
{
cnt = 0;
char a[100][100];

memset(map,0,sizeof(map));

memset(a,0,sizeof(a));

memset(colour,-1,sizeof(colour));

int i , j ;

for(i = 0 ;i < n ;i++)
{
cin>>a[i];
}
for(i = 0 ; i < n ;i++)
{
for( j = 2 ; j < n + 2;j++)
{
if(a[i][j] == '\0') break;

map[i][int(a[i][j] - 'A')] = 1;

map[int(a[i][j] - 'A')][i] = 1;
}//生成邻接矩阵
}
if( solve(0,1) )
{cout<<"1 channel needed."<<endl;continue;}
else if( solve(0,2))
{cout<<"2 channels needed."<<endl;continue;}
else if(solve(0,3))
{cout<<"3 channels needed."<<endl;continue;}
else
cout<<"4 channels needed."<<endl;


}
return 0;
}
...全文
49 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

64,646

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧