public int totalNQueens(int n) {
if (n == 1) return 1;
// 第i行的皇后放在那一列
int[] records = new int[n];
return process(records, n, 0);
}
private int process(int[] records, int n, int rowIdx) {
if (rowIdx == n) {
return 1;
}
int res = 0;
for (int i = 0; i < n; i++) {
if (isValid(records, rowIdx, i)) {
records[rowIdx] = i;
res += process(records, n, rowIdx+1);
}
}
return res;
}
private boolean isValid(int[] records, int x, int y) {
for (int i = 0; i < x; i++) {
if (records[i] == y || y - records[i] == x - i || y - records[i] == i - x) {
return false;
}
}
return true;
}
52. N皇后 II
最新推荐文章于 2025-05-23 17:12:19 发布