您可以帮我把这段C程序注释一下吗?我看不懂。谢谢您了
#include<stdio.h>intcol[8],Left[15],Right[15];intqueen[8];intn=0;intsum=0;intq[20];vo...
# include <stdio.h>
int col[8],Left[15],Right[15];
int queen[8];
int n=0;
int sum=0;
int q[20];
void Queens(int,int);
int Place(int,int);
void print(int);
int main()
{
int n;
printf("输入皇后数量\n");
scanf("%d",&n);
Queens(1,n);
system("pause");
return 0;
}
void Queens(int k,int n)
{
int i;
if(n<k)
print(n);
else
{
for(i=1;i<=n;i++)
if(Place(i,k)==1)
{
q[k]=i;
Queens(k+1,n);
}
}
}
int Place(int i,int k)
{
int j=1;
while(j<k)
{
if((q[j]==i)||abs(q[j]-i)==abs(j-k))
return 0;
j++;
}
return 1;
}
void print(int n)
{
int i;
for(i=1;i<=n;i++)
printf("<%d,%d>\t",i,q[i]);
printf("\n");
} 展开
int col[8],Left[15],Right[15];
int queen[8];
int n=0;
int sum=0;
int q[20];
void Queens(int,int);
int Place(int,int);
void print(int);
int main()
{
int n;
printf("输入皇后数量\n");
scanf("%d",&n);
Queens(1,n);
system("pause");
return 0;
}
void Queens(int k,int n)
{
int i;
if(n<k)
print(n);
else
{
for(i=1;i<=n;i++)
if(Place(i,k)==1)
{
q[k]=i;
Queens(k+1,n);
}
}
}
int Place(int i,int k)
{
int j=1;
while(j<k)
{
if((q[j]==i)||abs(q[j]-i)==abs(j-k))
return 0;
j++;
}
return 1;
}
void print(int n)
{
int i;
for(i=1;i<=n;i++)
printf("<%d,%d>\t",i,q[i]);
printf("\n");
} 展开
1个回答
展开全部
# include <stdio.h>
# include <math.h>
int col[8],Left[15],Right[15];
int queen[8];
int n=0;
int sum=0;
int q[20];
int sum1=0;
void Queens(int,int);
int Place(int,int);
void print(int);
int main()
{
int n;
printf("输入皇后数量\n");
scanf("%d",&n);
Queens(1,n);
printf("%d\n",sum1);
return 0;
}
void Queens(int k,int n)
{
int i;
if(n<k)
print(n);
else
{
//每一行从第一列开始遍历
for(i=1;i<=n;i++)
//第k行第i列可以放皇后时,则立马进入下一行,每一行只能一个皇后
if(Place(i,k)==1)
{
//标记
q[k]=i;
//进入下一行
Queens(k+1,n);
}
}
}
int Place(int i,int k) //这个函数就是判定那个位置能不能放皇后啦
{
int j=1;
while(j<k)
{
if((q[j]==i)||abs(q[j]-i)==abs(j-k)) //i列k行不能放时
return 0; //返回结果false
j++;
}
return 1; //能放得话就是TRUE
}
void print(int n)
{
int i;
//打印结果
for(i=1;i<=n;i++)
printf("<%d,%d>\t",i,q[i]);
sum1++;
printf("\n");
}
# include <math.h>
int col[8],Left[15],Right[15];
int queen[8];
int n=0;
int sum=0;
int q[20];
int sum1=0;
void Queens(int,int);
int Place(int,int);
void print(int);
int main()
{
int n;
printf("输入皇后数量\n");
scanf("%d",&n);
Queens(1,n);
printf("%d\n",sum1);
return 0;
}
void Queens(int k,int n)
{
int i;
if(n<k)
print(n);
else
{
//每一行从第一列开始遍历
for(i=1;i<=n;i++)
//第k行第i列可以放皇后时,则立马进入下一行,每一行只能一个皇后
if(Place(i,k)==1)
{
//标记
q[k]=i;
//进入下一行
Queens(k+1,n);
}
}
}
int Place(int i,int k) //这个函数就是判定那个位置能不能放皇后啦
{
int j=1;
while(j<k)
{
if((q[j]==i)||abs(q[j]-i)==abs(j-k)) //i列k行不能放时
return 0; //返回结果false
j++;
}
return 1; //能放得话就是TRUE
}
void print(int n)
{
int i;
//打印结果
for(i=1;i<=n;i++)
printf("<%d,%d>\t",i,q[i]);
sum1++;
printf("\n");
}
来自:求助得到的回答
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询