| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 415 人关注过本帖
标题:新手上路,求解一段n皇后程序,望大家帮我看看下面的程序
只看楼主 加入收藏
往返
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2010-12-16
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:2 
新手上路,求解一段n皇后程序,望大家帮我看看下面的程序
#include<stdio.h>
#include<conio.h>

#include<stdlib.h>
int q[20];
int count=0;
void print(int n)
{
int i;
count++;
for(i=1;i<=n;i++)
{printf("(%d,%d)",i,q[i]);
}
printf("\n");
}

int Place(int i,int k)
{
    int j;
j=1;
while(j<k)
{if((q[j]==i) || abs(q[j]-i)==abs(j-k)) return 0;
j++;
}
return 1;
}

void Queens(int k,int n)
{
    int i;
if(k>n)
print(n);
else
{for(i=1;i<=n;i++)
if(Place(i,k)==1)
{q[k]=i;
Queens(k+1,n);
}
}
}

int main()
{
    int n;
    printf("Please input n: ");
scanf("%d",&n);
Queens(1,n);
getch();
return 0;
}
搜索更多相关主题的帖子: 皇后 求解 
2010-12-16 15:20
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:20 
#include<stdio.h>
#include<math.h>
int q[20];
int count=0;
int resultcount=0;
void print(int n)//打印函数
 {int i;
 count++;//count++
 for(i=1;i<=n;i++)
  {printf("(%d,%d)",i,q[i]);
  }
 printf("n");
 }
int Place(int i,int k)
 {int j;
 j=1;
 while(j<k)
  {if((q[j]==i) || abs(q[j]-i)==abs(j-k)) return 0;//就说明不能放入这个皇后,return 0;
  j++;
  }
 return 1;//如果没有执行到if条件,即可以放入N个皇后,返回1值
 }
void Queens(int k,int n)
 {
 int i;//i为循环搜索皇后用
 if(k>n)//如果皇后数小于1,那么结果只有一种,递归结束条件
   print(n);//打印n
 else
  {for(i=1;i<=n;i++)//小于n循环
    if(Place(i,k)==1)//  判断是否可以将皇后放入这个位置,如果可以
     {q[k]=i;//复制,递归
     Queens(k+1,n);//继续递归,直到结束
     }
  }
 }
int main()
 {
 int n;//n为有几个皇后
 printf("please input the N queens:n");
 scanf("%d",&n);
 Queens(1,n);//调用queens函数
 getchar();
 printf("The result is %d",count);
 return 0;
 }

欢迎来到我的博客:http://blog..cn/noisunyuhong
2010-12-16 18:03
往返
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2010-12-16
收藏
得分:0 
谢谢你啦
2010-12-17 13:22
快速回复:新手上路,求解一段n皇后程序,望大家帮我看看下面的程序
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.039758 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved