Cod sursa(job #2180884)

Utilizator andreisavulescuSavulescu Andrei andreisavulescu Data 21 martie 2018 11:52:02
Problema Problema Damelor Scor 90
Compilator cpp Status done
Runda Arhiva educationala Marime 0.86 kb
#include <fstream>
#include <cmath>
using namespace std;
ifstream f("damesah.in");
ofstream g("damesah.out");
int n, x[40], nrsol = 0, ok = 0;
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 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 == 0)
                {
                    for(int i = 1; i <= n; i++)
                        g << x[i] << ' ';
                    g << '\n';
                    ok = 1;
                }
            nrsol++;
        }
}
int main()
{
    f >> n;
    bt(1);
    g << nrsol;
    return 0;
}