# include
# include
int col[8],Left[15],Right[15];
int queen[8];
int n=0;
int sum=0;
int q[20];
void Queens(int,int);
int Place(int,int);
void print(int);
int main()
{
int n;
printf("输入皇后数量\n");
scanf("%d",&n);
Queens(1,n);
return 0;
}
void Queens(int k,int n)
{
int i;
if(n
else
{
//每一行从第一列开始遍历
for(i=1;i<=n;i++)
//第k行第i列可以放皇后时,则立马进入下一行,每一行只能一个皇后
if(Place(i,k)==1)
{
//标记
q[k]=i;
//进入下一行
Queens(k+1,n);
}
}
}
int Place(int i,int k) //这个函数就是判定那个位置能不能放皇后啦
{
int j=1;
while(j
if((q[j]==i)||abs(q[j]-i)==abs(j-k)) //i列k行不能放时
return 0; //返回结果false
j++;
}
return 1; //能放得话就是TRUE
}
void print(int n)
{
int i;
//打印结果
for(i=1;i<=n;i++)
printf("<%d,%d>\t",i,q[i]);
printf("\n");
}