Cod sursa(job #2295007)

Utilizator TooHappyMarchitan Teodor TooHappy Data 2 decembrie 2018 23:51:49
Problema Problema Damelor Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.94 kb
#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;
}