AcWing 843. n-皇后问题
原题链接
中等
作者:
GTDI
,
2022-12-01 13:33:54
,
所有人可见
,
阅读 123
#include<iostream>// 三个for循环中i的起始都与主函数中dfs()有关
using namespace std;
const int N=20;
int n;
int col[N], dg[N], udg[N];
char g[N][N];
void dfs(int u)
{
if(u==n)
{
for(int i=0;i<n;i++) puts(g[i]);
puts("");
return ;
}
for(int i=0;i<n;i++)
{
if(!col[i]&&!dg[u+i]&&!udg[n-u+i])
{
g[u][i]='Q';
col[i]=dg[u+i]=udg[n-u+i]=true;
dfs(u+1);
col[i]=dg[u+i]=udg[n-u+i]=false;
g[u][i]='.';
}
}
}
int main()
{
cin>>n;
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
g[i][j]='.';
dfs(0);
return 0;
}