Cod sursa(job #1150534)

Utilizator c0rn1Goran Cornel c0rn1 Data 23 martie 2014 11:16:00
Problema Problema Damelor Scor 90
Compilator cpp Status done
Runda Arhiva educationala Marime 0.66 kb
#include <stdio.h>
using namespace std;
int n, sol[20], ok, ii, d2[25], d1[25], col[25];

void backt(int lin)
{
    if(lin==n+1)
    {
        for(++ok; ok<=1 && ii<n; printf("%d ", sol[++ii]));
        return;
    }
    for(int i=1; i<=n; ++i)
        if(!col[i] && !d1[lin+i-1] && !d2[lin-i+n])
        {
            sol[lin]=i; d1[lin+i-1]=1; d2[lin-i+n]=1;
            col[i]=1;
            backt(lin+1);
            d1[lin+i-1]=0; d2[lin-i+n]=0; col[i]=0;
        }
}

int main()
{
    freopen("damesah.in", "r", stdin);
    freopen("damesah.out", "w", stdout);
    scanf("%d", &n);
    backt(1);
    printf("\n%d", ok);
    return 0;
}