Cod sursa(job #2011960)

Utilizator victorv88Veltan Victor victorv88 Data 17 august 2017 16:17:17
Problema Problema Damelor Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.8 kb
#include <iostream>
#include <fstream>
using namespace std;

ifstream f("damesah.in");
ofstream g("damesah.out");

int sol[100], vizc[50], vizds[50], vizdp[50],n, nr=0;

void afisare()
{
    for (int i=0; i<n; i++)
        g << sol[i]+1 <<' ';
    g << endl;
}

void backt(int k)
{
    if (k==n)
    {
        if(nr==0)
            afisare();
        nr++;
        return;
    }
    for (int v=0; v<n; v++)
    {
        if (vizc[v]==0 && vizdp[k-v+n]==0 && vizds[k+v]==0)
        {
            sol[k]=v;
            vizc[v]=1;
            vizdp[k-v+n]=1;
            vizds[k+v]=1;
            backt(k+1);
            vizc[v]=0;
            vizdp[k-v+n]=0;
            vizds[k+v]=0;
        }
    }
}

int main()
{
    f >> n;
    backt(0);
    g << nr;
    return 0;
}