八皇后问题之一

原创 2016年05月31日 22:54:53

题意:八皇后问题是一个以国际象棋为背景的问题:如何能够在 8×8 的国际象棋棋盘上放置八个皇后,使得任何一个皇后都无法直接吃掉其他的皇后?为了达到此目的,任两个皇后都不能处于同一条横行、纵行或斜线上。
算法描述:
回溯法——在约束条件下先序遍历,并在遍历过程中剪去那些不满足条件的分支。
使用回溯算法求解的问题特征,求解问题要分为若干步,且每一步都有几种可能的选择,而且往往在某个选择不成功时需要回头再试另外一种选择,如果到达求解目标则每一步的选择构成了问题的解,如果回头到第一步且没有新的选择则问题求解失败。 在回溯策略中,也可以通过引入一些与问题相关的信息来加快搜索解的速度。对于皇后问题来说,由于每一行、每一列和每一个对角线,都只能放一个皇后,当一个皇后放到棋盘上后,不管它放在棋盘的什么位置,它所影响的行和列方向上的棋盘位置是固定的,因此在行、列方面没有什么信息可以利用。但在不同的位置,在对角线方向所影响的棋盘位置数则是不同的。可以想象,如果把一个皇后放在棋盘的某个位置后,它所影响的棋盘位置数少,那么给以后放皇后留下的余地就太大,找到解的可能性也大;反之留有余地就小,找到解的可能性也小。
//判断方向


  for(i=0;i<4;i++)
    {
        if(*(*(chess+i)+j)!=0)//*(chess+i)+j是第i行第j列元素的地址,*(*(chess+i)+j)是第i行第j列元素所对应的值
        {
            flag1 = 1;
            break;
        }
    }

//判断左上方


    for(i=row,k=j;i>=0&&k>=0;i--,k--)
    {
        if(*(*(chess+i)+k)!=0)
        {
            flag2 = 1;
            break;
        }
    }

//判断右下方

 for(i=row,k=j;i<4&&k<4;i++,k++)
    {
        if(*(*(chess+i)+k)!=0)
        {
            flag3 = 1;
            break;
        }
    }

//判断右上方

    for(i=row,k=j;i>=0&&k<4;i--,k++)
    {
        if(*(*(chess+i)+k)!=0)
        {
            flag4 = 1;
            break;
        }
    }

未完待续……..

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

八皇后问题的C++实现

  • 2017年09月23日 08:39
  • 446KB
  • 下载

八皇后问题

  • 2015年12月14日 16:22
  • 119KB
  • 下载

面试题-八皇后问题[算法]

题目:在8×8的国际象棋上摆放八个皇后,使其不能相互攻击,即任意两个皇后不得处在同一行、同一列或者同一对角斜线上。下图中的每个黑色格子表示一个皇后,这就是一种符合条件的摆放方法。请求出总共有多少种摆法...

八皇后问题

  • 2015年07月07日 18:13
  • 36KB
  • 下载

八皇后问题的C语言程序

  • 2014年09月12日 17:14
  • 516KB
  • 下载

八皇后问题优雅解法——位运算

古老的八皇后问题估计大家都不陌生。一个8✖️ 8的棋盘,放置八个皇后(Queen),每个皇后会攻击和自己在同一行(列),同一左(右)对角线上的其他皇后。如何放置这8个皇后,才能使得没有任何皇后会互相攻...

北邮数据结构 八皇后问题

  • 2014年01月28日 09:20
  • 3.66MB
  • 下载

八皇后问题

  • 2014年03月06日 10:48
  • 758KB
  • 下载

八皇后问题(python版理解)

一、 前言 八皇后问题是一个经典的数学问题,同时也是一个典型的回溯问题,《Python基础教程》简单的思路是:首先尝试在第1行放置第1个皇后,然后在第2行某个位置放置皇后,依次进行,当发现某行的...

八皇后问题

  • 2013年11月29日 16:19
  • 1KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:八皇后问题之一
举报原因:
原因补充:

(最多只允许输入30个字)