Pagini recente » Cod sursa (job #2598640) | Cod sursa (job #84008) | Cod sursa (job #821706) | Cod sursa (job #1357356) | Cod sursa (job #2295007)
#include <bits/stdc++.h>
using namespace std;
ifstream in("damesah.in");
ofstream out("damesah.out");
const int Nmax = 15;
int n, ans, sol[Nmax];
bool col[Nmax], mainDiag[2 * Nmax], secondDiag[2 * Nmax];
void bkt(int k) {
if(k == n + 1) {
ans++;
if(ans == 1) {
for(int i = 1; i <= n; ++i) {
out << sol[i] << " ";
}
out << "\n";
}
} else {
for(int i = 1; i <= n; ++i) {
if(!col[i] && !mainDiag[i - k + n - 1] && !secondDiag[i + k]) {
sol[k] = i;
col[i] = mainDiag[i - k + n - 1] = secondDiag[k + i] = true;
bkt(k + 1);
col[i] = mainDiag[i - k + n - 1] = secondDiag[k + i] = false;
}
}
}
}
int main() {
ios::sync_with_stdio(false); in.tie(0); out.tie(0);
in >> n;
bkt(1);
out << ans << "\n";
in.close(); out.close();
return 0;
}