Pagini recente » Cod sursa (job #2731518) | Cod sursa (job #3305956) | Cod sursa (job #1733391) | Cod sursa (job #1812791) | Cod sursa (job #3332718)
#include <iostream>
#include <cmath>
using namespace std;
int n, x[20];
long long total = 0;
bool afisat = false;
bool valid(int k)
{
for (int i = 1; i < k; i++)
if (x[k] == x[i] || abs(k - i) == abs(x[k] - x[i]))
return false;
return true;
}
void afisprsol()
{
for (int i = 1; i <= n; i++)
cout << x[i] << " ";
cout << "\n";
afisat = true;
}
void backt(int k)
{
for (int v = 1; v <= n; v++)
{
x[k] = v;
if (valid(k))
{
if (k == n)
{
total++;
if (!afisat)
afisprsol();
}
else
backt(k + 1);
}
}
}
int main()
{
cin >> n;
backt(1);
cout << total << "\n";
return 0;
}