-
Notifications
You must be signed in to change notification settings - Fork 28
/
N_Queens.cpp
40 lines (35 loc) · 1.22 KB
/
N_Queens.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
class Solution {
public:
bool isPlace(int queen, int col, int *arr) {
for(int prev = 1; prev < queen; ++prev) {
if(arr[prev] == col or abs(arr[prev] - col) == abs(prev - queen))
return false;
}
return true;
}
void solveNQueensUtils(int queen, vector<vector<string> > &result, vector<string> &solution, string Row, int n, int *arr) {
if(queen == n + 1) {
result.push_back(solution);
return;
}
for(int col = 1; col <= n; ++col) {
if(isPlace(queen, col, arr)) {
arr[queen] = col;
Row[col - 1] = 'Q';
solution.push_back(Row);
Row[col - 1] = '.';
solveNQueensUtils(queen + 1, result, solution, Row, n, arr);
solution.pop_back();
}
}
}
vector<vector<string> > solveNQueens(int n) {
vector <vector <string> > result;
vector <string> solution;
int arr[n + 1]; // arr[row] = col
string Row;
for(int k = 0; k < n; ++k) Row += '.';
solveNQueensUtils(1, result, solution, Row, n, arr);
return result;
}
};