【回溯】【DFS】51.N皇后
2023-12-19 05:36:18
class Solution {
public List<List<String>> solveNQueens(int n) {
List<List<String>> res = new ArrayList<>();
char[][] tmp = new char[n][n];
for (int i = 0; i < n; ++i) {
Arrays.fill(tmp[i], '.');
}
dfs(tmp, 0, res);
return res;
}
public void dfs(char[][] tmp, int layer, List<List<String>> res) {
int n = tmp.length;
if (layer == n) {
List<String> solu = new ArrayList<>();
for (int k = 0; k < n; ++k) {
solu.add(String.valueOf(tmp[k]));
}
res.add(solu);
return;
}
for (int k = 0; k < n; ++k) {
if (isValid(tmp, layer, k)) {
tmp[layer][k] = 'Q';
dfs(tmp, layer + 1, res);
tmp[layer][k] = '.';
}
}
}
boolean isValid(char[][] tmp, int x, int y) {
int n = tmp.length;
for (int i = 0; i < n; ++i) {
if (tmp[i][y] == 'Q' && i < x) {
return false;
}
}
int i = 1;
while (x - i >= 0 && y - i >= 0) {
if (tmp[x - i][y - i] == 'Q') {
return false;
}
++i;
}
i = 1;
while (x - i >= 0 && y + i < n) {
if (tmp[x - i][y + i] == 'Q') {
return false;
}
++i;
}
return true;
}
}
文章来源:https://blog.csdn.net/Allenlzcoder/article/details/135074968
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!