设计一种算法,打印 N 皇后在 N × N 棋盘上的各种摆法,其中每个皇后都不同行、不同列,也不在对角线上。这里的“对角线”指的是所有的对角线,不只是平分整个棋盘的那两条对角线。
注意:本题相对原题做了扩展
示例:
输入:4
输出:[[".Q..","...Q","Q...","..Q."],["..Q.","Q...","...Q",".Q.."]]
解释: 4 皇后问题存在如下两个不同的解法。
[
[".Q..", // 解法 1
"...Q",
"Q...",
"..Q."],
["..Q.", // 解法 2
"Q...",
"...Q",
".Q.."]
]
分析:
方法:DFS+回溯
我们可以定义一个数组存储每一行皇后的位置,然后按照行的顺序进行遍历,每遍历一次判断那一行哪些位置能添加皇后,添加后继续遍历下一层,若遍历完成,就记录结果,然后回溯到上一层,继续判断后面的位置是否能添加。
时间复杂度:O(n!) n 为皇后数量
空间复杂度:O(n)
class Solution {
//创建棋盘,记录每层皇后的位置
int[] chess;
//棋盘边长
int len;