文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档>八皇后问题

八皇后问题

时间:2010-07-23  来源:Z_Q_2010

问题描述:在一个8*8的国际棋盘上有8个皇后,每个皇后占一格,要求任意两个皇后都不能处在同一行,同一列或同一对角线上。

#include<stdio.h>
#include<math.h>

const int N=8;

int site[N];

int isValid(int n)
{
    int i;

    for(i = 0 ; i < n ; i++)
    {
        if(site[i] == site[n])
            return 0;

        if(abs(site[i] - site[n]) == (n - i))
            return 0;
    }

    return 1;
}

void queen(int depth)
{
    int i;

    if(depth == N)                
    {
        for(int i=0;i<N;i++)
            printf("%4d",site[i]);
        printf("\n");

        return;
    }

    for(i = 1 ; i <= N ; i++)
    {
        site[depth] = i;

        if(isValid(depth))
            queen(depth+ 1);                    
    }
}

int main()
{
queen(0);

return 0;
}

 

八皇后采用深度优先搜索的方式从前到后依次枚举每一行上的位置,当该位置满足要求时,就向下搜索


 

相关阅读 更多 +
排行榜 更多 +
三角符文第一章下载

三角符文第一章下载

角色扮演 下载
嘀嘀动画官方正版下载

嘀嘀动画官方正版下载

趣味娱乐 下载
像素世界僵尸危机安卓版

像素世界僵尸危机安卓版

飞行射击 下载