Pagini recente » Cod sursa (job #1068215) | Cod sursa (job #583704) | Cod sursa (job #1562929) | Cod sursa (job #416978) | Cod sursa (job #2670410)
#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[15], diag2[15];
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;
}