ACM----HDU-2553 N皇后问题

在N*N的方格棋盘放置了N个皇后,使得它们不相互攻击(即任意2个皇后不允许处在同一排,同一列,也不允许处在与棋盘边框成45角的斜线上。
你的任务是,对于给定的N,求出有多少种合法的放置方法。

Input

共有若干行,每行一个正整数N≤10,表示棋盘和皇后的数量;如果N=0,表示结束。

Output

共有若干行,每行一个正整数,表示对应输入行的皇后的不同放置数量。

Sample Input

1
8
5
0

Sample Output

1
92
10

解题思路:用dfs一行一行得进行摆放,x为当前行,n为总行数,用for循环来确定每一列,由于是一行一行得摆放所以不可能同行,只需要标记同列,与主对角线(左下到右上)平行的一条对角线上的行列和等于同一个常数,副对角线(左上到右下)平行一条对角线行列差等于一个常数,只不过会是负数,防止下标是负数我们可以进行+10,保证是一个正数,利用这个性质来确定有没有同行同列。

 1 #include<stdio.h>
 2 
 3 int count=0;
 4 
 5 bool ye[10],d1[50],d2[50];//用于判断对应竖行、主对角线、副对角线是否已经有棋
 6 bool check(int x,int y){
 7     if(ye[y]||d1[x+y]||d2[x-y+10])//判断竖行和两对角线上是否有棋
 8         return 0;
 9     return 1;
10 }
11 void dfs(int x,int n){
12     if(x==n){
13         count++;
14         return ;
15     }
16     for(int i=0;i<n;i++){
17         if(check(x,i)){//如果满足条件即该位置可以放棋
18             ye[i]=1;d1[x+i]=1;d2[x-i+10]=1;
19             dfs(x+1,n);
20             ye[i]=0;d1[x+i]=0;d2[x-i+10]=0;
21         }
22     }
23 
24 }
25 int main(){
26     int N;
27     for(int i=1;i<=10;i++)
28     {
29         count=0;
30         dfs(0,i);
31         printf("%d,",count);
32     }
33     return 0;
34 }

 

posted @ 2021-01-29 18:09  AA、  阅读(77)  评论(0编辑  收藏  举报