Pagini recente » Cod sursa (job #570108) | Cod sursa (job #1734191) | Cod sursa (job #1526452) | Cod sursa (job #2987565) | Cod sursa (job #2774923)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("damesah.in");
ofstream fout("damesah.out");
int N, cnt;
int st[15];
bool col[15];
bool valid(int k) {
for(int i = 1; i < k; i++) {
if(abs(st[k] - st[i]) == k - i) {
return 0;
}
}
return 1;
}
void bkt(int k) {
for(int i = 1; i <= N; i++) {
if(col[i] == 1) {
continue;
}
st[k] = i;
col[st[k]] = 1;
if(valid(k)) {
if(k == N) {
cnt++;
if(cnt == 1) {
for(int i = 1; i <= N; i++) {
fout << st[i] << " ";
}
fout << '\n';
}
} else {
bkt(k + 1);
}
}
col[st[k]] = 0;
}
}
int main() {
fin >> N;
bkt(1);
fout << cnt << '\n';
return 0;
}