Cod sursa(job #2016521)

Utilizator adimiclaus15Miclaus Adrian Stefan adimiclaus15 Data 29 august 2017 16:34:46
Problema Problema Damelor Scor 90
Compilator cpp Status done
Runda Arhiva educationala Marime 0.88 kb
#include <iostream>
#include <fstream>
#include <cmath>
using namespace std;
ifstream f("damesah.in");
ofstream g("damesah.out");
int a[15],n,nr;
int valid(int k)
{
    int i;
    for(i=1;i<k;i++)
    {
        if(a[i]==a[k] || abs(a[i]-a[k])==abs(i-k))
        {
            return 0;
        }
    }
    return 1;
}
void afisare()
{
    int i;
    for(i=1;i<=n;i++)
    {
        g<<a[i]<<" ";
    }
    g<<"\n";
}
void bkt(int k)
{
    int i;
    for(i=1;i<=n;i++)
    {
        a[k]=i;
        if(valid(k)==1)
        {
            if(k==n)
            {
                nr++;
                if(nr==1)
                {
                    afisare();
                }
            }
            else
            {
                bkt(k+1);
            }
        }
    }
}
int main()
{
    f>>n;
    bkt(1);
    g<<nr<<"\n";
    return 0;
}