mirror of
				https://github.com/krahets/hello-algo.git
				synced 2025-11-04 06:07:20 +08:00 
			
		
		
		
	Update n_queens code.
This commit is contained in:
		@ -19,8 +19,8 @@ void backtrack(int row, int n, vector<vector<string>> &state, vector<vector<vect
 | 
			
		||||
        // 计算该格子对应的主对角线和副对角线
 | 
			
		||||
        int diag1 = row - col + n - 1;
 | 
			
		||||
        int diag2 = row + col;
 | 
			
		||||
        // 剪枝:不允许该格子所在 (列 或 主对角线 或 副对角线) 包含皇后
 | 
			
		||||
        if (!(cols[col] || diags1[diag1] || diags2[diag2])) {
 | 
			
		||||
        // 剪枝:不允许该格子所在列、主对角线、副对角线存在皇后
 | 
			
		||||
        if (!cols[col] && !diags1[diag1] && !diags2[diag2]) {
 | 
			
		||||
            // 尝试:将皇后放置在该格子
 | 
			
		||||
            state[row][col] = "Q";
 | 
			
		||||
            cols[col] = diags1[diag1] = diags2[diag2] = true;
 | 
			
		||||
 | 
			
		||||
@ -24,8 +24,8 @@ public class n_queens {
 | 
			
		||||
            // 计算该格子对应的主对角线和副对角线
 | 
			
		||||
            int diag1 = row - col + n - 1;
 | 
			
		||||
            int diag2 = row + col;
 | 
			
		||||
            // 剪枝:不允许该格子所在 (列 或 主对角线 或 副对角线) 包含皇后
 | 
			
		||||
            if (!(cols[col] || diags1[diag1] || diags2[diag2])) {
 | 
			
		||||
            // 剪枝:不允许该格子所在列、主对角线、副对角线存在皇后
 | 
			
		||||
            if (!cols[col] && !diags1[diag1] && !diags2[diag2]) {
 | 
			
		||||
                // 尝试:将皇后放置在该格子
 | 
			
		||||
                state[row][col] = "Q";
 | 
			
		||||
                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
 | 
			
		||||
		diag2 := row + col
 | 
			
		||||
		// 剪枝:不允许该格子所在 (列 或 主对角线 或 副对角线) 包含皇后
 | 
			
		||||
		if !((*cols)[col] || (*diags1)[diag1] || (*diags2)[diag2]) {
 | 
			
		||||
		// 剪枝:不允许该格子所在列、主对角线、副对角线存在皇后
 | 
			
		||||
		if !(*cols)[col] && !(*diags1)[diag1] && !(*diags2)[diag2] {
 | 
			
		||||
			// 尝试:将皇后放置在该格子
 | 
			
		||||
			(*state)[row][col] = "Q"
 | 
			
		||||
			(*cols)[col], (*diags1)[diag1], (*diags2)[diag2] = true, true, true
 | 
			
		||||
 | 
			
		||||
@ -26,8 +26,8 @@ public class n_queens {
 | 
			
		||||
            // 计算该格子对应的主对角线和副对角线
 | 
			
		||||
            int diag1 = row - col + n - 1;
 | 
			
		||||
            int diag2 = row + col;
 | 
			
		||||
            // 剪枝:不允许该格子所在 (列 或 主对角线 或 副对角线) 包含皇后
 | 
			
		||||
            if (!(cols[col] || diags1[diag1] || diags2[diag2])) {
 | 
			
		||||
            // 剪枝:不允许该格子所在列、主对角线、副对角线存在皇后
 | 
			
		||||
            if (!cols[col] && !diags1[diag1] && !diags2[diag2]) {
 | 
			
		||||
                // 尝试:将皇后放置在该格子
 | 
			
		||||
                state.get(row).set(col, "Q");
 | 
			
		||||
                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 diag2 = row + col;
 | 
			
		||||
        // 剪枝:不允许该格子所在 (列 或 主对角线 或 副对角线) 包含皇后
 | 
			
		||||
        if (!(cols[col] || diags1[diag1] || diags2[diag2])) {
 | 
			
		||||
        // 剪枝:不允许该格子所在列、主对角线、副对角线存在皇后
 | 
			
		||||
        if (!cols[col] && !diags1[diag1] && !diags2[diag2]) {
 | 
			
		||||
            // 尝试:将皇后放置在该格子
 | 
			
		||||
            state[row][col] = 'Q';
 | 
			
		||||
            cols[col] = diags1[diag1] = diags2[diag2] = true;
 | 
			
		||||
 | 
			
		||||
@ -24,8 +24,8 @@ def backtrack(
 | 
			
		||||
        # 计算该格子对应的主对角线和副对角线
 | 
			
		||||
        diag1 = row - col + n - 1
 | 
			
		||||
        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"
 | 
			
		||||
            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 diag2 = row + col
 | 
			
		||||
        // 剪枝:不允许该格子所在 (列 或 主对角线 或 副对角线) 包含皇后
 | 
			
		||||
        if !(cols[col] || diags1[diag1] || diags2[diag2]) {
 | 
			
		||||
        // 剪枝:不允许该格子所在列、主对角线、副对角线存在皇后
 | 
			
		||||
        if !cols[col] && !diags1[diag1] && !diags2[diag2] {
 | 
			
		||||
            // 尝试:将皇后放置在该格子
 | 
			
		||||
            state[row][col] = "Q"
 | 
			
		||||
            cols[col] = true
 | 
			
		||||
 | 
			
		||||
@ -24,8 +24,8 @@ function backtrack(
 | 
			
		||||
        // 计算该格子对应的主对角线和副对角线
 | 
			
		||||
        const diag1 = row - col + n - 1;
 | 
			
		||||
        const diag2 = row + col;
 | 
			
		||||
        // 剪枝:不允许该格子所在 (列 或 主对角线 或 副对角线) 包含皇后
 | 
			
		||||
        if (!(cols[col] || diags1[diag1] || diags2[diag2])) {
 | 
			
		||||
        // 剪枝:不允许该格子所在列、主对角线、副对角线存在皇后
 | 
			
		||||
        if (!cols[col] && !diags1[diag1] && !diags2[diag2]) {
 | 
			
		||||
            // 尝试:将皇后放置在该格子
 | 
			
		||||
            state[row][col] = 'Q';
 | 
			
		||||
            cols[col] = diags1[diag1] = diags2[diag2] = true;
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user