文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
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;
}

 

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


 

相关阅读 更多 +
排行榜 更多 +
辰域智控app

辰域智控app

系统工具 下载
网医联盟app

网医联盟app

运动健身 下载
汇丰汇选App

汇丰汇选App

金融理财 下载