Pagini recente » Cod sursa (job #14663) | Cod sursa (job #2558997) | Cod sursa (job #2643123) | Cod sursa (job #79486) | Cod sursa (job #2670411)
#include <fstream>
#include <cmath>
#include <stdlib.h>
using namespace std;
ifstream fin("damesah.in");
ofstream fout("damesah.out");
int n, x[15], ct = 0;
bool c[15], diag[30], diag2[30];
void Complete(int k)
{
for(int i = 1; i <= k; i++)
fout << x[i] <<' ';
fout<<'\n';
}
void Back(int k)
{
for(int i = 1; i <= n; i++)
{
x[k] = i;
if(c[x[k]] == 0 && diag[x[k] + k] == 0 && diag2[x[k] - k + n] == 0)
{
c[x[k]] = 1;
diag[x[k] + k] = 1;
diag2[x[k] - k + n] = 1;
if(k == n)
{
if(ct == 0)
Complete(k);
ct++;
}
else
Back(k + 1);
c[x[k]] = 0;
diag[x[k] + k] = 0;
diag2[x[k] - k + n] = 0;
}
}
}
int main()
{
fin >> n;
Back(1);
fout << ct;
return 0;
}