抽象DFS:N皇后问题

简介: 抽象DFS:N皇后问题

  在一张N∗N的国际象棋棋盘上,放置N个皇后,使得所有皇后都无法互相直接攻击得到,(皇后可以直接攻击到她所在的横行,竖列,斜方向上的棋子),现在输入一个整数N,表示在N∗N的棋盘上放N个皇后,请输出共有多少种使得所有皇后都无法互相直接攻击得到的方案数。 例如下面这样的摆法,是4皇后的一个解 (1代表有皇后,0代表没有)


0 1 0 0


0 0 0 1


1 0 0 0


0 0 1 0


输入


一个整数N,代表皇后的个数


输出


输出方案数


样例输入1


4


样例输出1


2


样例输入2


8


样例输出2


92

 


注意一条对角线的行和列的和或者行和列的差是定值

#include <iostream>
using namespace std;
int n;
int count;
bool b[200],b1[400],b2[200];
bool in(int x,int y){
  return !b[y]&&!b1[x+y]&&!b2[x-y+n];   //b代表列,b1和b2表示对角线
}
void dfs(int x){
  if(x==n){
    count++;       //遍历到第n行证明该方法可行
    return;
  }
  for(int i=0;i<n;i++){   //x行,i列
    if(in(x,i)){        //如果x行i列可以放置皇后
      b[i]=b1[x+i]=b2[x-i+n]=1;
      dfs(x+1);       //在改点放置皇后,并且到下一行寻找可行皇后放置点放置
      b[i]=b1[x+i]=b2[x-i+n]=0;
    }
  }
}
int main(){
  cin>>n;
  dfs(0);         //从第零行开始选择
  cout<<count;
  return 0;
}

   

相关文章
|
8月前
|
算法
Hierholzer算法dfs找欧拉回路模板
Hierholzer算法dfs找欧拉回路模板
82 0
|
存储 算法
深度优先遍历(DFS):探索图的奥秘
当进行深度优先遍历(DFS)时,我们需要按照一定的步骤来遍历图中的节点。 选择起始节点:选择图中的一个起始节点作为遍历的起点。 标记已访问:将起始节点标记为已访问,并将其放入数据结构中,比如栈或递归调用。 探索相邻节点:从起始节点开始,探索与其相邻的节点。这是通过查找邻接表来实现的,邻接表存储了每个节点的相邻节点信息。 深入探索:选择一个相邻节点,标记为已访问,并将其放入数据结构中。然后,从这个相邻节点出发,继续探索其相邻节点,形成一个深入的路径。这一步是递归的核心。 回溯:当没有未访问的相邻节点时,回溯到上一个节点,继续探索其他未访问的相邻节点。这可以通过从数据结构中弹出节点来实现,或者从递
320 0
|
机器学习/深度学习 存储 算法
【DFS经典例题】2n皇后问题
【DFS经典例题】2n皇后问题
84 0
|
机器学习/深度学习
抽象DFS:2N皇后
抽象DFS:2N皇后