leetcode第51题:N皇后问题 [困难]

2020-11-15  本文已影响0人  nlpming
题目描述
image.png
考点
解题思路
image.png
代码实现
class Solution {
private:
    void backtracking(vector<vector<string>>& ans, vector<string>& board, vector<bool>& column, 
        vector<bool>& ldiag, vector<bool>& rdiag, int row, int n){
            if(row == n){
                ans.push_back(board);
                return;
            }

            // NOTE: 左对角线,row+col相等;右对角线,n-1+row-col相等;
            for(int i = 0; i < n; i++){
                if(column[i] || ldiag[row+i] || rdiag[n-1+row-i]){
                    continue;
                }

                // 修改当前结点状态,表示已访问
                board[row][i] = 'Q';
                column[i] = ldiag[row+i] = rdiag[n-1+row-i] = true;

                // 递归遍历后续行
                backtracking(ans, board, column, ldiag, rdiag, row+1, n);

                // 回溯过程
                board[row][i] = '.';
                column[i] = ldiag[row+i] = rdiag[n-1+row-i] = false;
            }
        }
public:
    vector<vector<string>> solveNQueens(int n) {
        vector<vector<string>> ans;
        if(n == 0)
            return ans;
        
        // board存储返回结果
        vector<string> board(n, string(n, '.'));
        vector<bool> column(n, false), ldiag(2*n-1, false), rdiag(2*n-1, false);

        // 从第0行开始递归
        backtracking(ans, board, column, ldiag, rdiag, 0, n);
        return ans;
    }
};
上一篇 下一篇

猜你喜欢

热点阅读