Cod sursa(job #3137891)

Utilizator andreea0146Nicula Andreea andreea0146 Data 15 iunie 2023 21:04:39
Problema Problema Damelor Scor 90
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.71 kb
#include <fstream>
#include <cmath>
using namespace std;
ifstream fin("damesah.in");
ofstream fout("damesah.out");

int n, x[30], nrsol;
bool ok;
bool valid(int k)
{
    for(int i = 1; i < k; i++)
        if(x[k] == x[i] || k - i == abs(x[k] - x[i]))
            return 0;
    return 1;
}

void afis()
{
    nrsol++;
    if(ok==0)
    for(int i = 1; i <= n; i++)
        fout << x[i] << ' ';
    ok=1;
}

void backt(int k)
{
    if(k <= n)
        for(int v = 1; v <= n; v++)
        {
            x[k] = v;
            if(valid(k))
                backt(k + 1);
        }
    else
        afis();
}

int main()
{
    fin >> n;
    backt(1);
    fout<<'\n'<<nrsol;
    return 0;
}