Pagini recente » Cod sursa (job #2342112) | Cod sursa (job #927248) | Cod sursa (job #1357165) | Cod sursa (job #1886036) | Cod sursa (job #2231046)
#include <bits/stdc++.h>
using namespace std;
ifstream fin ("damesah.in");
ofstream fout ("damesah.out");
int n, k;
int answer[15];
bool row[14];
bool first_Diagonal[28];
bool second_Diagonal[28];
void backtracking(int line)
{
if ( line > n )
{
k++;
if ( k == 1 )
{
for ( int i = 1; i <= n; ++i )
fout<<answer[i]<<" ";
fout<<'\n';
}
return;
}
for ( int i = 1; i <= n; ++i )
{
if ( row[i] == false && first_Diagonal[i-line+n] == false && second_Diagonal[i+line] == false )
{
answer[line] = i;
row[i] = true;
first_Diagonal[i-line+n] = true;
second_Diagonal[i+line] = true;
backtracking(line+1);
row[i] = false;
first_Diagonal[i-line+n] = false;
second_Diagonal[i+line] = false;
}
}
}
int main()
{
fin>>n;
backtracking(1);
fout<<k<<'\n';
}