程序员面试金典-面试题 08.12. 八皇后

题目:

设计一种算法,打印 N 皇后在 N × N 棋盘上的各种摆法,其中每个皇后都不同行、不同列,也不在对角线上。这里的“对角线”指的是所有的对角线,不只是平分整个棋盘的那两条对角线。

注意:本题相对原题做了扩展

示例:

输入:4
输出:[[".Q..","...Q","Q...","..Q."],["..Q.","Q...","...Q",".Q.."]]
解释: 4 皇后问题存在如下两个不同的解法。
[
 [".Q..",  // 解法 1
  "...Q",
  "Q...",
  "..Q."],

 ["..Q.",  // 解法 2
  "Q...",
  "...Q",
  ".Q.."]
]

分析:

经典老题了,就不多说了,下面有一篇已经写好的讲解,不懂的同学可以移步下面看看。

LeetCode 51. N-QueensN皇后 (C++)(八皇后问题)

程序:

class Solution {
    public List<List<String>> solveNQueens(int n) {
        cols = new int[n];
        leftDiagonal = new int[n * 2 - 1];
        rightDiagonal = new int[n * 2 - 1];
        List<List<String>> res = new ArrayList<>();
        char[][] chess = new char[n][n];
        for(int i = 0; i < n; ++i)
            for(int j = 0; j < n; ++j)
                chess[i][j] = '.';
        dfs(chess, res, 0, n);
        return res;
    }
    private void dfs(char[][] chess, List<List<String>> res, int x, int n){
        if(x == n){
            List<String> list = new ArrayList<>();
            for(char[] c:chess){
                list.add(new String(c));
            }
            res.add(list);
            return;
        }
        for(int y = 0; y < n; ++y){
            if(cols[y] == 1 || leftDiagonal[-x+y+n-1] == 1 || rightDiagonal[-x-y+(n-1)*2] == 1)
                continue;
            cols[y] = 1;
            leftDiagonal[-x+y+n-1] = 1;
            rightDiagonal[-x-y+(n-1)*2] = 1;
            chess[x][y] = 'Q';
            dfs(chess, res, x+1, n);
            cols[y] = 0;
            leftDiagonal[-x+y+n-1] = 0;
            rightDiagonal[-x-y+(n-1)*2] = 0;
            chess[x][y] = '.';
        }
        return;
    }
    private int[] cols;
    //-x+y+n-1
    private int[] leftDiagonal;
    //-x-y+(n-1)*2
    private int[] rightDiagonal;
}

 

posted @ 2020-03-12 14:22  silentteller  阅读(295)  评论(0编辑  收藏  举报