Pagini recente » Cod sursa (job #2628758) | Cod sursa (job #1564328) | Cod sursa (job #1390023) | Cod sursa (job #2528922) | Cod sursa (job #2738699)
#include <bits/stdc++.h>
using namespace std;
ifstream f("damesah.in");
ofstream g("damesah.out");
int OK=1,n,nr,sol[15],fv1[101],fv2[101],fv3[101];
void beck(int k)
{
int dif;
if(k==n+1)
{
nr++;
if(OK)
{
OK=0;
for(int i=1;i<k;i++)g<<sol[i]<<" ";
}
}
else
{
for(int i=1;i<=n;i++)
{
sol[k]=i;
if(k>i)dif=k-i;
else dif=(i-k)+50;
fv1[i]++;
fv2[dif]++;
fv3[k+i]++;
if(fv1[i]==1 && fv2[dif]==1 && fv3[k+i]==1)beck(k+1);
fv1[i]--;
fv2[dif]--;
fv3[k+i]--;
}
}
}
int main()
{
f>>n;
beck(1);
g<<'\n'<<nr;
return 0;
}