[C++][算法基础]n-皇后问题(DFS)

n−皇后问题是指将 n 个皇后放在 n×n 的国际象棋棋盘上,使得皇后不能相互攻击到,即任意两个皇后都不能处于同一行、同一列或同一斜线上。

现在给定整数 n,请你输出所有的满足条件的棋子摆法。

输入格式

共一行,包含整数 n。

输出格式

每个解决方案占 n 行,每行输出一个长度为 n 的字符串,用来表示完整的棋盘状态。

其中 . 表示某一个位置的方格状态为空,Q 表示某一个位置的方格上摆着皇后。

每个方案输出完成后,输出一个空行。

注意:行末不能有多余空格。

输出方案的顺序任意,只要不重复且没有遗漏即可。

数据范围

1≤n≤9

输入样例:
复制代码
4
输出样例:
复制代码
.Q..
...Q
Q...
..Q.

..Q.
Q...
...Q
.Q..

代码:

cpp 复制代码
#include<iostream>
using namespace std;

const int N = 20;
char path[N][N];
int row[N],k[N],uk[N];
int n;

void dfs(int now){
    if(now == n){
        for(int p = 0;p<n;p++){
            for(int q = 0;q<n;q++){
                cout<<path[p][q];
            }
            cout<<endl;
        }
        cout<<endl;
    }else{
        for(int j = 0;j<n;j++){
            if(row[j] == 0 && k[j + now] == 0 && uk[n+j-now] == 0){
                row[j] = 1;
                k[j + now] = 1;
                uk[n+j-now] = 1;
                path[now][j] = 'Q';
                dfs(now+1);
                row[j] = 0;
                k[j + now] = 0;
                uk[n+j-now] = 0;
                path[now][j] = '.';
            }
        }
    }
}

int main(){
    cin>>n;
    for(int p = 0;p<n;p++){
        for(int q = 0;q<n;q++){
            path[p][q] = '.';
            
        }
        row[p] = 0;
        k[p] = 0;
        uk[p] = 0;
    }
    dfs(0);
    return 0;
}
相关推荐
R-G-B38 分钟前
【15】OpenCV C++实战篇——fitEllipse椭圆拟合、 Ellipse()画椭圆
c++·人工智能·opencv·fitellipse椭圆拟合·ellipse画椭圆·椭圆拟合·绘制椭圆
2501_924731471 小时前
城市路口识别准确率↑31%!陌讯时空建模算法在交通拥堵识别中的突破
人工智能·算法·目标检测·计算机视觉·目标跟踪
熬了夜的程序员2 小时前
【华为机试】208. 实现 Trie (前缀树)
数据结构·算法·华为od·华为
界面开发小八哥3 小时前
MFC扩展库BCGControlBar Pro v36.2:MSAA和CodedUI测试升级
c++·mfc·bcg·界面控件
小O的算法实验室4 小时前
2024年ESWA SCI1区TOP,自适应种群分配和变异选择差分进化算法iDE-APAMS,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
不吃洋葱.5 小时前
左子树之和
算法
金融小师妹5 小时前
基于AI量化模型的比特币周期重构:传统四年规律是否被算法因子打破?
大数据·人工智能·算法
极客BIM工作室6 小时前
C++ 限制类对象数量的技巧与实践
开发语言·javascript·c++
郝学胜-神的一滴6 小时前
Horse3D引擎研发笔记(四):在QtOpenGL下仿three.js,封装EBO绘制四边形
c++·3d·unity·游戏引擎·godot·图形渲染·虚幻
数据智能老司机6 小时前
图算法趣味学——最短路径
数据结构·算法·云计算