n 皇后问题研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击。
上图为 8 皇后问题的一种解法。
给定一个整数 n,返回所有不同的 n 皇后问题的解决方案。
输入: 4
输出: 2
解释: 4 皇后问题存在如下两个不同的解法。
[
[".Q..", // 解法 1
"...Q",
"Q...",
"..Q."],
["..Q.", // 解法 2
"Q...",
"...Q",
".Q.."]
]
回溯法:深度优先遍历(列数作为同级,行数作为深层)+ 剪枝
- 递归深度达到最后一层:达到一个符合条件的解,向上回溯,想结果中添加当前的皇后位置列表
- 循环所有同级向深层递归,将每一层皇后的位置进行记录
- 当前位置在已放好皇后的攻击范围内:当前位置不能放置皇后
- 没有命中上面的规则,说明当前位置可放置皇后,向更深层递归
- 将结果进行可视化绘制
var solveNQueens = function (n) {
const cols = new Set();
const left = new Set();
const right = new Set();
const result = []
solveNQueensCore(0, n, cols, left, right, result, []);
return draw(result, n);
};
var solveNQueensCore = function (row, n, cols, left, right, result, temp) {
if (row === n) {
result.push([...temp]);
temp = [];
}
for (let i = 0; i < n; i++) {
if (!cols.has(i) && !right.has(row - i) && !left.has(row + i)) {
cols.add(i);
left.add(row + i);
right.add(row - i);
temp[row] = i;
solveNQueensCore(row + 1, n, cols, left, right, result, temp);
cols.delete(i);
left.delete(row + i);
right.delete(row - i);
}
}
};
function draw(array, n) {
const result = [];
array.forEach(element => {
const panel = [];
element.forEach(index => {
const temp = new Array(n).fill('.');
temp[index] = 'Q';
panel.push(temp.join(''));
});
result.push(panel);
});
return result;
}