| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1438 人关注过本帖
标题:八皇后问题
取消只看楼主 加入收藏
功夫熊猫
Rank: 2
等 级:论坛游民
帖 子:54
专家分:30
注 册:2010-7-14
结帖率:78.57%
收藏
已结贴  问题点数:20 回复次数:2 
八皇后问题
#include<stdio.h>
int a[8][8]={0};
fun(int n,int a[8][8])
{
    int i,j,m,p,q;
    if(n=7)return 1;
    for(i=0;i<=7;i++)
    {
        p=n;q=i;
        while(p>=0&&q>=0)
        {if(a[p--][q--]!=0)break;}/*检测左上方是否有皇后*/
    if(!(p==0||q==0))continue;
    p=n;q=i;
    while(p<=7&&q<=7)
    {if(a[p++][q++]!=0)break;}/*右下方*/
    if(!(p==7||q==7))continue;
    p=n;q=i;
    while(p>=0&&p<=7&&q>=0&&q<=7)
    {if(a[p++][q--]!=0)break;}/*左下方*/
    if(!(p==0||p==7||q==0||q==7))continue;
    p=n;q=i;
    while(p>=0&&p<=7&&q>=0&&q<=7)
    {if(a[p--][q++]!=0)break;}/*右上方*/
    if(!(p==0||p==7||q==0||q==7))continue;
   
    for(j=0;j<=7;j++)
    if(a[i][j]==0&&a[j][i]==0)continue;/*上下左右*/
    if(j==7)
    a[n][i]=1;
    break;
    }
    fun(n+1,a);
}
main()
{
    int n=0,i,j;
    for(n=0;n<=7;n++)
    {
        if(fun(n,a)==1)
        {
            for(i=0;i<=7;i++)
        {    for(j=0;j<=7;j++)
            printf("%5d",a[i][j]);
        printf("\n");}
        printf("\n");
        }
    }
}
在国际象棋中,把八个皇后放在棋盘上,使它们中任何一个都无法攻击其余的皇后,这个程序那些地方有问题。。。求大虾赐教
搜索更多相关主题的帖子: 皇后 
2010-09-16 18:18
功夫熊猫
Rank: 2
等 级:论坛游民
帖 子:54
专家分:30
注 册:2010-7-14
收藏
得分:0 
能不能把流程图画出来
2010-09-16 21:52
功夫熊猫
Rank: 2
等 级:论坛游民
帖 子:54
专家分:30
注 册:2010-7-14
收藏
得分:0 
好复杂啊
2010-09-16 22:51
快速回复:八皇后问题
数据加载中...
 
   



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

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