`

八皇后问题——之全排列解法

 
阅读更多

 

 

问题的分解一共有两步:

 

1. 生成问题的所有候选解空间
2. 过滤掉那些不满足要求的

 

细化这两步,需要认识到下面两点:

 

1. 八皇后所有候选解空间是:  [1,2,3,4,5,6,7,8] 这个集合中元素的全排列 

 

   (这个全排列不仅列出了候选解,并且还自动规避掉了皇后在横、竖方向上攻击的问题)

 

2. 接下来八皇后相互攻击的问题就是:任意两个皇后是否在一条对角线上,即两个皇后所在直线的斜率绝对值是否为1 。

  

清楚了上述两点后,代码就变得异常清晰、简单、直接了,要做的工作就是:

1. 生成 [1,2,3,4,5,6,7,8] 的全排列

2. 写出safe函数(判断斜率)

3. 根据safe函数过滤掉那些有冲突的解。

 

                                          code:  https://github.com/deyuwang/8queen

 

 

 

 

分享到:
评论

相关推荐

    八皇后问题——递归解决

    用递归解决八皇后问题的一段代码,专门写了较为详细的注释,本人原创,如有雷同,纯属巧合。

    八皇后问题——MIPs实现

    八皇后问题的MIPS实现,用MARS可跑出正确结果

    八皇后问题详细的解法-23页 PPT PDF版.pdf

    ### 八皇后问题详解 ...通过以上分析可以看出,八皇后问题的不同解法各有特点,从简单的枚举算法到高效的回溯法,每种方法都有其适用场景。在实际解决问题时,应根据问题的具体需求选择合适的算法。

    八皇后问题解法(c和c++)

    八皇后问题的两种解法,包含c方式和c++方式

    八皇后问题的一种解法(C语言源代码)

    这个是八皇后问题的一种解法,希望可以给大家参考,有需要的话可以看一下哦!

    八皇后问题求解——之递归

    ### 八皇后问题求解——之递归 #### 一、八皇后问题概述 八皇后问题是由国际西洋棋棋手马克斯·贝瑟尔在1848年提出的经典问题。这个问题要求在8×8的国际象棋棋盘上放置八个皇后,使得任意两个皇后之间都不能相互...

    八皇后 的三种解法 (java编写)

    首先,我们来了解一下八皇后问题的基本解法。一般来说,解决八皇后问题的方法主要有以下三种: 1. **深度优先搜索(DFS)**:这是最常见的解决方法,利用递归的方式,每次尝试在当前行放置一个皇后,并检查是否与前...

    java--八皇后问题的势力范围解法

    java--八皇后问题的势力范围解法: 用的是eclipse运行的,特色在于运用势力范围,每当放置一个皇后就会将其下面影响到的空格的势力值加1,每次回溯的时候减1,用一个2维数组保存,相当直观。

    八皇后问题的一种解法(拓展占位法)

    求解八皇后问题的一种算法,是用二维数组模拟了一个棋盘,每种结果都会输出来其中皇后的位置用"2"表示,其他位置用0或1表示。

    数据结构——八皇后问题

    八皇后问题的C++算法,运行、调试成功! 数据结构的八皇后问题。

    python八皇后解法

    八皇后解法.

    八皇后问题的scheme解法(queen8.scm)

    收集的用scheme语言编写的八皇后的解法,对学习scheme语言想理解递归的同志们是一个好例子,sicp中也有此练习题。

    递归算法举例——八皇后问题详解

    递 归 算 法 举 例——八皇后问题详解,和大家分享~

    mfc实现八皇后问题

    八皇后问题是一个经典的计算机编程问题,它涉及到回溯算法、数据结构和图形用户界面的设计。在C++中,特别是结合MFC(Microsoft Foundation Classes)框架,可以创建具有用户友好界面的程序来解决此问题。 首先,...

    八皇后问题回溯求解 matlab

    用回溯求解法求解八皇后问题,经典问题matlab实现,欢迎大家下载

    数据结构课程设计——八皇后问题

    在计算机科学和数学领域中,八皇后问题是一项经典的算法问题,它不仅是数据结构课程设计中的一个经典项目,也是训练算法设计和编程实践能力的有效途径。该问题要求在8x8的棋盘上放置8个皇后,使得它们互不攻击,即...

    关于皇后问题——算法

    ### 关于皇后问题的算法详解 #### 一、皇后问题简介 皇后问题是一个经典的计算机科学问题,主要探讨如何在一个N×N的棋盘上放置N个皇后,使得任意两个皇后都不能互相攻击。按照国际象棋的规则,皇后可以沿水平线、...

    爬山法、模拟退火法、遗传算法实现八皇后问题

    八皇后问题是一个著名的棋盘放置问题,要求在8×8的棋盘上摆放8个皇后,使得任意两个皇后都不能在同一行、同一列或同一对角线上。下面将详细解释这些方法以及它们在八皇后问题中的应用。 1. 爬山法: 爬山法是一种...

    八皇后问题解法.zip

    八皇后问题解法.zip

    八皇后问题的c解法 c源代码 回溯法

    八皇后问题 c源代码 回溯法 通过更改N的值可以演变成为N皇后 不过当N大于一定的数值时 电脑会花费比较长的时间哦

Global site tag (gtag.js) - Google Analytics