用c语言实现八皇后问题,哪里有错?

#include"stdio.h"#include"math.h"#defineN8intq[N];intplace(intk,intj){inti;for(i=0;i<... #include"stdio.h"
#include"math.h"
#define N 8
int q[N];
int place(int k,int j)
{
int i;
for(i=0;i<k;i++)
if(j==q[i]||abs(k-i)==abs(j-q[i]))
return 0;
return 1;
}
void queen(int k,int n)
{
int j;
for(j=0;j<n;j++)
if(place(k,j))
{
q[k]=j;
break;
}
}
void main()
{

int f[N][N];
int i,j;
for(i=0;i<N;i++)
queen(i,N);
for(i=0;i<N;i++)
for(j=0;j<N;j++)
{
if(q[i]==j)
f[i][j]=1;
else
f[i][j]=0;
}
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
printf("%-2d",f[i][j]);
printf("\n");
}
}
展开
 我来答
缘明思
2016-10-31 · TA获得超过543个赞
知道小有建树答主
回答量:795
采纳率:88%
帮助的人:341万
展开全部
没发现有什么回溯啊~也没看出有什么递归啊。你觉得你一趟就能尝试出解吗?只用单纯的循环不是不能解,就是你写的循环还太少了点呢~
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式