Cod sursa(job #1950636)

Utilizator BourucLiviuBouruc Petru Liviu BourucLiviu Data 3 aprilie 2017 10:38:43
Problema Problema Damelor Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.91 kb
#include <cstdio>
#include <cmath>

using namespace std;

int n, v[15], nr;
bool col[15], diag_st[35], diag_dr[35];
bool gasit;

void afiseaza()
{
    for(int i = 1; i <= n; ++i) printf("%d ", v[i]);
}

void Dame(int k)
{
    if(k == n + 1)
    {
        if(!gasit)
        {
            afiseaza();
            gasit = 1;
        }
        nr++;
    }
    else
        for(int i = 1; i <= n; ++i)
            if(!col[i] && !diag_st[i-k+n-1] && !diag_dr[k+i])
            {
                v[k] = i;
                col[i] = diag_st[i-k+n-1] = diag_dr[k+i] = 1;
                Dame(k+1);
                col[i] = diag_st[i-k+n-1] = diag_dr[k+i] = 0;
            }
}

int main()
{
    freopen("damesah.in", "r", stdin);
    freopen("damesah.out", "w", stdout);

    scanf("%d", &n);
    fclose(stdin);

    Dame(1);

    printf("\n%d", nr);
    fclose(stdout);
    return 0;
}