Pagini recente » Cod sursa (job #760855) | Cod sursa (job #635068) | Atasamentele paginii Clasament cevaproblemeoji | Cod sursa (job #1818286) | Cod sursa (job #1258443)
#include <fstream>
#define lmax 15
using namespace std;
ifstream f("damesah.in");
ofstream g("damesah.out");
int n,nr;
int sol[lmax];
int folc[lmax],fold[lmax];
inline int modul(int a)
{
return a>=0?a:-a;
}
inline void tipar()
{
for (int i=1;i<=n;i++)
g<<sol[i]<<" ";
}
inline bool valid(int k)
{
for(int i=1;i<k;i++)
if (modul(i-k)==modul(sol[i]-sol[k]))
return 0;
return 1;
}
inline void back(int k)
{
if (k==n+1)
{
nr++;
if (nr==1)
tipar();
}
else
{
for (int i=1;i<=n;i++)
if (folc[i]==0)
{
sol[k]=i;
folc[i]=1;
if (valid(k))
back(k+1);
folc[i]=0;
}
}
}
int main()
{
f>>n;
back(1);
g<<'\n'<<nr;
f.close();
g.close();
}