정답 풀이
#include <bits/stdc++.h>
using namespace std;
bool isused1[40]; // column을 차지하고 있는지
bool isused2[40]; // / 방향 대각선을 차지하고 있는지
bool isused3[40]; // \ 방향 대각선을 차지하고 있는지
int cnt = 0;
int n;
void func(int cur) { // cur번째 row에 말을 배치할 예정임
if (cur == n) { // N개를 놓는데 성공했다면
cnt++;
return;
}
for (int i = 0; i < n; i++) { // (cur, i)에 퀸을 놓을 예정
if (isused1[i] || isused2[i+cur] || isused3[cur-i+n-1]) // column이나 대각선 중에 문제가 있다면
continue;
isused1[i] = 1;
isused2[i+cur] = 1;
isused3[cur-i+n-1] = 1;
func(cur+1);
isused1[i] = 0;
isused2[i+cur] = 0;
isused3[cur-i+n-1] = 0;
}
}
int main(void) {
ios::sync_with_stdio(0);
cin.tie(0);
cin >> n;
func(0);
cout << cnt;
}
'Algorithm > C++' 카테고리의 다른 글
[백준 15650] N과 M (2) (0) | 2022.09.16 |
---|---|
[백준 1182] 부분수열의 합 (0) | 2022.09.15 |
[백준 15649] N과 M (1) - 백트래킹 (0) | 2022.09.15 |
[백준 2447] 별 찍기 -10 (0) | 2022.09.14 |
[백준 2206] 벽 부수고 이동하기 (0) | 2022.09.14 |
댓글