/* N皇后问题,num为皇后个数。
please input num of queens:
4
2413 3142
共2个解.
please input num of queens:
5
13524 14253 24135 25314 31425 35241 41352 42531 52413 53142
共10个解.
please input num of queens:
8
15863724 16837425 17468253 17582463 24683175 25713864 25741863 26174835 26831475 27368514 27581463 28613574 31758246 35281746 35286471 35714286 35841726 36258174 36271485 36275184 36418572 36428571 36814752 36815724 36824175 37285146 37286415 38471625 41582736 41586372 42586137 42736815 42736851 427
51863 42857136 42861357 46152837 46827135 46831752 47185263 47382516 47526138 47531682 48136275 48157263 48531726 51468273 51842736 51863724 52468317 52473861 52617483 52814736 53168247 53172864 53847162 57138642 57142863 57248136 57263148 57263184 57413862 58413627 58417263 61528374 62713584 627148
53 63175824 63184275 63185247 63571428 63581427 63724815 63728514 63741825 64158273 64285713 64713528 64718253 68241753 71386425 72418536 72631485 73168524 73825164 74258136 74286135 75316824 82417536 82531746 83162574 84136275
共92个解.
please input num of queens:
*/
#include<stdio.h>
#include <math.h>
void main()
{
int a[100],n,i,j,k,flag,count,num;
while(1)
{
count=0;
printf("please input num of queens:\n");
scanf("%d",&num);
n=num;i=1;
a[1] = 1;
while(1)
{
flag=1;
for(k=i-1;k>=1;k--)
{
if(a[i]==a[k]||abs(a[i]-a[k])==i-k) // 同列,或者对角,则破flag
flag=0;
}
if(flag&&i==num) //如果走了num步,还没有破flag,则发现一个解
{
for(j=1;j<=n;j++)
printf("%d",a[j]); //结果存储在a
printf(" ");
count++;
}
if(i<n&&flag)
{
i++;
a[i]=1;
continue;
}
while(a[i]==n&&i>1)
{
i--; }//回溯 : 13 回溯到1,
14回溯到4 (4皇后的话)
if(a[i]==n&&i==1)
break;
else
a[i]=a[i]+1;
}
printf("\n 共%d个解.\n",count);
}
}