Cod sursa(job #1893648)

Utilizator gabrielamoldovanMoldovan Gabriela gabrielamoldovan Data 25 februarie 2017 21:00:37
Problema Problema Damelor Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.77 kb
#include <iostream>
#include <fstream>

using namespace std;

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

int n, queen[20], sol;
bool col[20], diag_p[40], diag_s[40];

void backtracking(int l)
{
    if(l==n+1)
    {
        if(sol<1)
        {
            for(int i=1; i<=n; ++i)
            {
                g<<queen[i]<<" ";
            }
        }
        sol++;
    }
    for(int i=1; i<=n; ++i)
    {
        if(!col[i] && !diag_p[i+l] && !diag_s[i+n-1-l])
        {
            queen[l]=i;
            col[i]=diag_p[i+l]=diag_s[i+n-1-l]=true;
            backtracking(l+1);
            col[i]=diag_p[i+l]=diag_s[i+n-1-l]=false;
        }
    }
}

int main()
{
    f>>n;
    backtracking(1);
    g<<"\n"<<sol;
    return 0;
}