Cod sursa(job #2157076)

Utilizator andreisavulescuSavulescu Andrei andreisavulescu Data 9 martie 2018 10:58:08
Problema Problema Damelor Scor 90
Compilator cpp Status done
Runda Arhiva educationala Marime 0.75 kb
#include <fstream>
#include <cmath>
using namespace std;
ifstream f("damesah.in");
ofstream g("damesah.out");
int n, x[40], nrsol = 0,ok=1;
bool valid(int k)
{
    for(int i = 1; i < k; i++)
    {
        if(x[k] == x[i]) return 0;
        if(k - i == abs(x[k] - x[i])) return 0;
    }
    return 1;
}
void prelsol()
{
    ok=0;
    nrsol++;
    for(int i = 1; i <= n; i++)
        g << x[i] << ' ';
    g << endl;
}
void bt(int k)
{
    if(k <= n)
        for(int i = 1; i <= n; i++)
        {
            x[k] = i;
            if(valid(k) == 1)
                bt(k + 1);
        }
    else
        if(ok==1)
        prelsol();
        else nrsol++;
}
int main()
{
    f >> n;
    bt(1);
    g << nrsol;
    return 0;
}