Update n_queens code.

pull/558/head
krahets 1 year ago
parent ba1e5c1d7d
commit 9fc1a0b2b3

@ -19,8 +19,8 @@ void backtrack(int row, int n, vector<vector<string>> &state, vector<vector<vect
// 计算该格子对应的主对角线和副对角线 // 计算该格子对应的主对角线和副对角线
int diag1 = row - col + n - 1; int diag1 = row - col + n - 1;
int diag2 = row + col; int diag2 = row + col;
// 剪枝:不允许该格子所在 (列 或 主对角线 或 副对角线) 包含皇后 // 剪枝:不允许该格子所在列、主对角线、副对角线存在皇后
if (!(cols[col] || diags1[diag1] || diags2[diag2])) { if (!cols[col] && !diags1[diag1] && !diags2[diag2]) {
// 尝试:将皇后放置在该格子 // 尝试:将皇后放置在该格子
state[row][col] = "Q"; state[row][col] = "Q";
cols[col] = diags1[diag1] = diags2[diag2] = true; cols[col] = diags1[diag1] = diags2[diag2] = true;

@ -24,8 +24,8 @@ public class n_queens {
// 计算该格子对应的主对角线和副对角线 // 计算该格子对应的主对角线和副对角线
int diag1 = row - col + n - 1; int diag1 = row - col + n - 1;
int diag2 = row + col; int diag2 = row + col;
// 剪枝:不允许该格子所在 (列 或 主对角线 或 副对角线) 包含皇后 // 剪枝:不允许该格子所在列、主对角线、副对角线存在皇后
if (!(cols[col] || diags1[diag1] || diags2[diag2])) { if (!cols[col] && !diags1[diag1] && !diags2[diag2]) {
// 尝试:将皇后放置在该格子 // 尝试:将皇后放置在该格子
state[row][col] = "Q"; state[row][col] = "Q";
cols[col] = diags1[diag1] = diags2[diag2] = true; cols[col] = diags1[diag1] = diags2[diag2] = true;

@ -21,8 +21,8 @@ func backtrack(row, n int, state *[][]string, res *[][][]string, cols, diags1, d
// 计算该格子对应的主对角线和副对角线 // 计算该格子对应的主对角线和副对角线
diag1 := row - col + n - 1 diag1 := row - col + n - 1
diag2 := row + col diag2 := row + col
// 剪枝:不允许该格子所在 (列 或 主对角线 或 副对角线) 包含皇后 // 剪枝:不允许该格子所在列、主对角线、副对角线存在皇后
if !((*cols)[col] || (*diags1)[diag1] || (*diags2)[diag2]) { if !(*cols)[col] && !(*diags1)[diag1] && !(*diags2)[diag2] {
// 尝试:将皇后放置在该格子 // 尝试:将皇后放置在该格子
(*state)[row][col] = "Q" (*state)[row][col] = "Q"
(*cols)[col], (*diags1)[diag1], (*diags2)[diag2] = true, true, true (*cols)[col], (*diags1)[diag1], (*diags2)[diag2] = true, true, true

@ -26,8 +26,8 @@ public class n_queens {
// 计算该格子对应的主对角线和副对角线 // 计算该格子对应的主对角线和副对角线
int diag1 = row - col + n - 1; int diag1 = row - col + n - 1;
int diag2 = row + col; int diag2 = row + col;
// 剪枝:不允许该格子所在 (列 或 主对角线 或 副对角线) 包含皇后 // 剪枝:不允许该格子所在列、主对角线、副对角线存在皇后
if (!(cols[col] || diags1[diag1] || diags2[diag2])) { if (!cols[col] && !diags1[diag1] && !diags2[diag2]) {
// 尝试:将皇后放置在该格子 // 尝试:将皇后放置在该格子
state.get(row).set(col, "Q"); state.get(row).set(col, "Q");
cols[col] = diags1[diag1] = diags2[diag2] = true; cols[col] = diags1[diag1] = diags2[diag2] = true;

@ -16,8 +16,8 @@ function backtrack(row, n, state, res, cols, diags1, diags2) {
// 计算该格子对应的主对角线和副对角线 // 计算该格子对应的主对角线和副对角线
const diag1 = row - col + n - 1; const diag1 = row - col + n - 1;
const diag2 = row + col; const diag2 = row + col;
// 剪枝:不允许该格子所在 (列 或 主对角线 或 副对角线) 包含皇后 // 剪枝:不允许该格子所在列、主对角线、副对角线存在皇后
if (!(cols[col] || diags1[diag1] || diags2[diag2])) { if (!cols[col] && !diags1[diag1] && !diags2[diag2]) {
// 尝试:将皇后放置在该格子 // 尝试:将皇后放置在该格子
state[row][col] = 'Q'; state[row][col] = 'Q';
cols[col] = diags1[diag1] = diags2[diag2] = true; cols[col] = diags1[diag1] = diags2[diag2] = true;

@ -24,8 +24,8 @@ def backtrack(
# 计算该格子对应的主对角线和副对角线 # 计算该格子对应的主对角线和副对角线
diag1 = row - col + n - 1 diag1 = row - col + n - 1
diag2 = row + col diag2 = row + col
# 剪枝:不允许该格子所在 (列 或 主对角线 或 副对角线) 包含皇后 # 剪枝:不允许该格子所在列、主对角线、副对角线存在皇后
if not (cols[col] or diags1[diag1] or diags2[diag2]): if not cols[col] and not diags1[diag1] and not diags2[diag2]:
# 尝试:将皇后放置在该格子 # 尝试:将皇后放置在该格子
state[row][col] = "Q" state[row][col] = "Q"
cols[col] = diags1[diag1] = diags2[diag2] = True cols[col] = diags1[diag1] = diags2[diag2] = True

@ -16,8 +16,8 @@ func backtrack(row: Int, n: Int, state: inout [[String]], res: inout [[[String]]
// 线线 // 线线
let diag1 = row - col + n - 1 let diag1 = row - col + n - 1
let diag2 = row + col let diag2 = row + col
// ( 线 线) // 线线
if !(cols[col] || diags1[diag1] || diags2[diag2]) { if !cols[col] && !diags1[diag1] && !diags2[diag2] {
// //
state[row][col] = "Q" state[row][col] = "Q"
cols[col] = true cols[col] = true

@ -24,8 +24,8 @@ function backtrack(
// 计算该格子对应的主对角线和副对角线 // 计算该格子对应的主对角线和副对角线
const diag1 = row - col + n - 1; const diag1 = row - col + n - 1;
const diag2 = row + col; const diag2 = row + col;
// 剪枝:不允许该格子所在 (列 或 主对角线 或 副对角线) 包含皇后 // 剪枝:不允许该格子所在列、主对角线、副对角线存在皇后
if (!(cols[col] || diags1[diag1] || diags2[diag2])) { if (!cols[col] && !diags1[diag1] && !diags2[diag2]) {
// 尝试:将皇后放置在该格子 // 尝试:将皇后放置在该格子
state[row][col] = 'Q'; state[row][col] = 'Q';
cols[col] = diags1[diag1] = diags2[diag2] = true; cols[col] = diags1[diag1] = diags2[diag2] = true;

Loading…
Cancel
Save