well,思路和上次一样
代码如下
#include<stdio.h>
#include<stdlib.h>
#define n 8
int a[n];
int count=0;
int jude()
{
int i,j;
for(i=0;i<n;i++)
{
for(j=i+1;j<n;j++)
if(a[i]==a[j])
return 0;
}
for(i=0;i<n;i++)
{
for(j=i+1;j<n;j++)
if((j-i)==abs(a[j]-a[i]))
return 0;
}
return 1;
}
void dfs(int t)
{
int i;
if(t==n)
{
if(jude())
{
for(i=0;i<n;i++)
printf("%3d",a[i]);
printf("\n");count++;
}
}
else
{
for(i=0;i<n;i++)
{
a[t]=i;
dfs(t+1);
}
}
}
int main()
{
dfs(0);
printf("%d\n",count);
return 0;
}