-2
#include <stdio.h>
#include <math.h>
char a[10][10];
int n;
int feasible(int row,int col)
{
int i,j,tcol;
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
if(a[i][j]=='Q')
break;
}
tcol=j;
if(col==tcol || abs(row-i)==abs(col-tcol))
return 0;
}
return 1;
}
void nqueen(int row)
{
int i,j;
if(row<n)
{
for(i=0;i<n;i++)
{
if(feasible(row,i))
{
a[row][i]='Q';
nqueen(row+1);
a[row][i]='.';
}
}
}
else
{
printf("\nThe solution is:\n");
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
printf("%c\t",a[i][j]);
}
printf("\n\n");
}
}
}
int main()
{
int i,j;
printf("Enter the number of queens:");
scanf("%d",&n);
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
a[i][j]='.';
}
}
nqueen(0);
getch();
return 0;
}
可行的功能是检查一个女王是否可以放在行&列通过。我女王之谜的代码有什么错误?
函数nqueen
给出了该问题的所有可能解决方案。 我没有得到任何输出在屏幕上。请帮忙!
请修复您的缩进。每行需要四个空格将文本格式化为代码,您甚至可以在不应该有任何C缩进的行上进行更多操作。 – unwind
n,我和j没有初始化! – Zelldon
你做了什么来发现问题? – Michas