C语言八皇后问题,解释代码是什么意思。if(queen[y]==x),初始化queen[]里面不全是0吗,怎么会相等?

#include<stdio.h>#defineN8intcolumn[N+1];intrup[2*N+1];intlup[2*N+1];intqueen[N+1]={0... #include<stdio.h>
#define N 8
int column[N+1];
int rup[2*N+1];
int lup[2*N+1];
int queen[N+1]={0}; //????
int num; //Case编号
void backtrack(int i); //递回求解
void main()
{
int i;
num=0;
for(i=1;i<=N;i++)
column[i]=1;
for(i=1;i<=2*N;i++)
rup[i]=lup[i]=1;
backtrack(1); //重新寻找符合要求的位置
}
void showAnswer() //输出结果
{
int x,y;
printf("\nCase %d\n",++num);
for(y=1;y<=N;y++)
{
for(x=1;x<=N;x++)
{
if(queen[y]==x) //??用queen[1]==?用数字演示一次这个循环
{
printf("■");//■表示皇后,输出时为白色方框
}
else
{
printf("□");
}
}
printf("\n");
}
}
void backtrack(int i) //递回求解
{
int j;
if(i>N) //不再回溯
{
showAnswer();
}
else
{
for(j=1;j<=N;j++)
{
if(column[j]==1 && rup[i+j]==1 && lup[i-j+N]==1)
{
queen[i]=j; //设为占用 //是如何设为占用的?
column[j]=rup[i+j]=lup[i-j+N]=0;
backtrack(i+1);
column[j]=rup[i+j]=lup[i-j+N]=1;
}
}
}
}
展开
 我来答
GTA小鸡
高粉答主

2014-12-31 · 醉心答题,欢迎关注
知道大有可为答主
回答量:2.6万
采纳率:78%
帮助的人:1.3亿
展开全部
程序执行时,先执行main()函数,main()函数先把flag都设为1,表示每行每列每对角线都没有重复(初始化)。然后调用backtrack(1)函数开始递归,这个函数一直递归到找到一个合适解为止,然后才执行showAnswer()函数输出这个解
if(queen[y]==x) 打印黑块 else 打印白块
就是把解输出到屏幕上显示出来
更多追问追答
追问
我是不明白它打印黑块的条件是什么意思。用1组数据演示一下这个for循环的值吧for(y=1;y<=N;y++) 
{
for(x=1;x<=N;x++)
{
if(queen[y]==x) //??用queen[1]==?用数字演示一次这个循环
{
printf("■");//■表示皇后,输出时为白色方框
追答
这个就是把数组的解输出到屏幕上
比如queen[y]数组是{6,2,7,1,4,8,5,3}
for循环就是在屏幕上画出来这个解
□□□□□■□□
□■□□□□□□
□□□□□□■□
■□□□□□□□
□□□■□□□□
□□□□□□□■
□□□□■□□□
□□■□□□□□
if(queen[y]==x) 如果该行第x个块记录为皇后就画黑块,否则画白块
heptnaol
2014-12-31 · TA获得超过7260个赞
知道大有可为答主
回答量:7120
采纳率:78%
帮助的人:1761万
展开全部
您没有理解这个算法的流程
backtrack调用完成后,queen数组的每一项内容都非0.

queen[i]=j; //设为占用 //是如何设为占用的?

就在你提问这一句,非0即被占用,j是几号,就被第几号占用,0就是空闲。
追问
用1组数据演示一下这个for循环的值吧for(y=1;y<=N;y++) 
{
for(x=1;x<=N;x++)
{
if(queen[y]==x) //??用queen[1]==?用数字演示一次这个循环
{
printf("■");//■表示皇后,输出时为白色方框
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式