Pagini recente » Cod sursa (job #2207339) | Cod sursa (job #1819215) | Cod sursa (job #1430711) | Cod sursa (job #722794) | Cod sursa (job #1150536)
#include <stdio.h>
using namespace std;
int n, sol[20], ok, ii, d2[30], d1[30], col[30];
void backt(int lin)
{
if(lin==n+1)
{
if (++ok==1)
for(; 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;
}