返回顶部
首页 > 资讯 > 后端开发 > Python >八皇后问题(python 生成器)
  • 231
分享到

八皇后问题(python 生成器)

生成器皇后python 2023-01-31 02:01:14 231人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

问题: 在8×8格的国际象棋上摆放八个皇后,使其不能互相***,即任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。大致是下面这种样式: 思路: 第一步:皇后位置存放问题 用列表或元组表示。索引表示皇后所在的横行。列表的值

问题:

在8×8格的国际象棋上摆放八个皇后,使其不能互相***,即任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。大致是下面这种样式:

e

思路:

第一步:皇后位置存放问题

用列表或元组表示。索引表示皇后所在的横行。列表的值表示 皇后的 竖列。

那么皇后位置可表示为: L[i]  i in range(8) 且 len(L) =8

第二步:冲突问题。

这种情况,没有考虑到冲突问题:

同一行,由于用索引 表示,所以不会起冲突。

同一行, L[n] 等于 L[i] 值。也或是说 :皇后a. 列表值 - 皇后b.列表值 = 0

斜行问题:

斜行有两个方面考虑,一种是正斜45度,一种是反斜45度。

相当于汉字中的撇捺。但不管那种情况。如果两个皇后是同斜行,必然是这样:

| 皇后a.行值 - 皇后b.行值  | == | 皇后a.列值 - 皇后b. 列值  |

绝对值【皇后a.索引-皇后b.索引 】= 绝对值 【皇后a.列表值 - 皇后b.列表值。】 。如下图所示:

2

设计处理模型:

第一步:皇后摆放顺序 。伪代码为说明:(假设总的要摆放皇后的个数为num =8 )

以上图为例,皇后按 一个一个摆放。

当摆放第N+1个时,整个棋盘状态: next = N+1

已摆放的位置放在列表 status 中: len ( status ) == N 。

第 N+1 个,能摆放的位置 是   range( num )。 for pos in range( num )

但是,这里需要排除 起冲突的。

# 第N+1 个皇后能摆放的位置:
# 此时:皇后位置列表:status,已摆放:len(status)
  
    for pos in range(num):
         if not drop_place(pos,status):    # 如果没有冲突继续摆放,否则返回。

第二步:排除冲突。

每一个已摆放好位置的皇后都要与第 N+1 个皇后 做比较,

for i in range(N):   第 i  行。

列值冲突  ,相等:  status[i]  -- pos == 0

斜着冲突: 行值 差等于 列值差的绝对值 。即

| status[i] – pos | =  len(status)  - i

#  pos 表示当前位置, status 表示前面摆放位置 
def drop_place(pos,status):

    nextY = len(status)        # 当前行号

    for i in range( nextY ):       # 已存在的位置都要比较
        if  abs(status[i] - pos ) in (0, nextY - i ):     #如果有位置冲突
            return True           # 直接返回冲突,否则继续比较
    return False           # 最后一个比较完,没有冲突返回 False.注意缩进

第三步,是否继续摆放:

这时需要考虑的是,本次摆放 的是不是 最后一个位置。

如果不是,那继续摆放。(递归摆放)

如果是最后一个位置.即 num –1. 如果是 那么是返回 pos 位置 还是 pos + status呢?

和第一个代码结合 :

def queens(num=8, status=[]):
    for pos in range(num):
        if not drop_place(pos,status):
            
            # 下面是继续摆放
            if len(status) != num -1:
               for each in queens(num,status+[pos,]): # 第一个?号
                  yield [pos,]+each                   # 第二个?号

            else:        # 最后一个
                yield [pos,]                          # 第三个?号

这里要解释下,为什么使用迭代生成器 而 不用 return。

第N 个皇后摆放时,有 range(num) 个位置。如果,使用 return,那么当第一个位置满足条件时,直接返回。我们这里需要的是所有满足摆放的位置。

位置是多个,所以 ,这里使用  for each in queens(num, status +[pos,]) . each 表示第 N+2 个皇后 满足 不冲突的位置。

status + [pos,] 表示当 添加 N+2 个皇后时,此时队列必须要加上N+1的位置。

第二个问号: 这里 为什么 用 生成 器 而不用 return ,就像我们上面说的那样,要生成所有满足 条件 的N+2位置,而不是一个位置就返回。

再看返回的队列,[pos,] + each.

这里 ,要再回想回想 递归的要求,必须是 递归的条件一步步满足停止递归的要求,否则递归 就是无限循环。

这里,我们要摆放完所有的皇后,必须是基于最后一个皇后的位置存在,然后,倒着存入 所有的位置。

而在摆放第N+2个皇后时,能确认的只有,pos + each 位置。

当 each = 最后一个皇后时,就会从最后一个位置反着添加所有皇后的位置,从而生成整个符合条件的位置。

第三个问号: 递归到最后一个皇后时,依然需要 使用 for each in queens(num, status+[pos,]) 得到最后一们的位置迭代对象。

所以,这里使用 yield 返回 [pos,],再依次相加。最后,得到符合条件的一列数组

大致代码如下:

def drop_place(pos,status):
    nextY = len(status) 
    for i in range( nextY ): 
        if  abs(status[i] - pos ) in (0, nextY - i ):
            return True 
    return False   

def queens(num=8, status=[] ):
    for pos in range(num):
        if not drop_place(pos,status):
            if len(status) == num - 1:
                yield [pos,]
            else:
                for result in queens(num, status +[pos,]):
                    yield [pos,]+result

print( len(list(queens(8))) )
# 显示的长度为 92
  

--结束END--

本文标题: 八皇后问题(python 生成器)

本文链接: https://lsjlt.com/news/186544.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 八皇后问题(python 生成器)
    问题: 在8×8格的国际象棋上摆放八个皇后,使其不能互相***,即任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。大致是下面这种样式: 思路: 第一步:皇后位置存放问题 用列表或元组表示。索引表示皇后所在的横行。列表的值...
    99+
    2023-01-31
    生成器 皇后 python
  • 八皇后问题(Python)
    一.问题简介 八皇后问题: 如何能在 8*8 的国际象棋棋盘上放置八个皇后,使得任何一个皇后都无法直接吃掉其他的皇后?为了到达此目的,任两个皇后都不能处于同一条横行、纵行或斜线上。 二.几种思路和方法 1.回溯法+递归思想  如图所示,圆...
    99+
    2023-09-29
    python 开发语言 算法
  • C语言回溯法解八皇后问题(八皇后算法)
    八皇后问题(N皇后问题)的回溯法求解 一、问题描述 在一个国际象棋棋盘上放置八个皇后,使得任何两个皇后之间不相互攻击,求出所有的布棋方法,并推广到N皇后情况。 二、参考资料 啥文字都...
    99+
    2024-04-02
  • python基础: 遍历与八皇后问题浅析
    遍历思想与八皇后问题       作为对《python基础教程》关于八皇后一节的补充说明,本文旨在使人从直觉上理解八皇后及其相关问题更进一步。       在固定大小的棋盘上,n个皇后所有的排列组合个数是有限的, 思路极为清晰:...
    99+
    2023-01-31
    遍历 皇后 基础
  • 如何利用 MySQL 解八皇后问题
    这篇文章主要介绍“如何利用 MySQL 解八皇后问题”,在日常操作中,相信很多人在如何利用 MySQL 解八皇后问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何利用 M...
    99+
    2024-04-02
  • 如何使用C语言解决八皇后问题
    这篇文章主要讲解了“如何使用C语言解决八皇后问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用C语言解决八皇后问题”吧!前言八皇后问题是一个古老而著名的问题。该问题是19世纪著名的数...
    99+
    2023-06-08
  • 浅谈Java实现回溯算法之八皇后问题
    目录一、前言二、浅谈递归三、回溯算法四、八皇后问题五、八皇后变种六、总结一、前言 说起八皇后问题,它是一道回溯算法类的经典问题,也可能是我们大部分人在上数据结构或者算法课上遇到过的最...
    99+
    2024-04-02
  • C语言如何使用回溯法解八皇后问题
    这篇文章给大家分享的是有关C语言如何使用回溯法解八皇后问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。八皇后问题(N皇后问题)的回溯法求解一、问题描述在一个国际象棋棋盘上放置八个皇后,使得任何两个皇后之间不相互...
    99+
    2023-06-22
  • 原:八皇后问题的递归和非递归Java实现
    原:八皇后问题的递归和非递归实现八皇后问题是一个古老而著名的问题,是回溯算法的典型例题。该问题是十九世纪著名 的数学家高斯1850年提出:在8X8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线...
    99+
    2023-06-03
  • 怎么使用Java递归回溯解决八皇后的问题
    这篇文章主要介绍“怎么使用Java递归回溯解决八皇后的问题”,在日常操作中,相信很多人在怎么使用Java递归回溯解决八皇后的问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用Java递归回溯解决八皇后...
    99+
    2023-06-25
  • Java使用递归回溯完美解决八皇后的问题
    八皇后问题 八皇后问题,是一个古老而著名的问题,是回溯算法的典型案例。该问题是国际西洋棋棋手马克斯·贝瑟尔于1848年提出:在8X8格的国际象棋上摆放八个皇后,使其不能互相攻击,即:...
    99+
    2024-04-02
  • 怎么在python中解决n皇后问题
    这期内容当中小编将会给大家带来有关怎么在python中解决n皇后问题,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。import copydef check(A,x,y): &...
    99+
    2023-06-14
  • Java基于循环递归回溯实现八皇后问题算法示例
    本文实例讲述了Java基于循环递归回溯实现八皇后问题。分享给大家供大家参考,具体如下:运行效果图如下:棋盘接口public interface Piece { abstract boolean isRow(int line); abst...
    99+
    2023-05-31
    java 八皇后 算法
  • C++实现LeetCode(51.N皇后问题)
    [LeetCode] 51. N-Queens N皇后问题 The n-queens puzzle is the problem of placing n...
    99+
    2024-04-02
  • python 非递归解决n皇后问题的方法
    复杂度可能高了点- - 也没太注意 我想了好久 也找了好久 没看到什么能够用python解决n皇后问题而且不调用递归的 因为我不太能理解递归(尤其是到n层时) 智商受限- - i...
    99+
    2024-04-02
  • Java通过递归算法解决迷宫与汉诺塔及八皇后问题
    目录1.递归的重要规则2.递归的三个案例1.老鼠出迷宫2.汉诺塔3.八皇后1.递归的重要规则 在执行一个方法时,就创建一个新的受保护的独立空间(栈空间)。方法的局部变量时独立的,不会...
    99+
    2024-04-02
  • C++实现LeetCode(52.N皇后问题之二)
    [LeetCode] 52. N-Queens II N皇后问题之二 The n-queens puzzle is the problem of placing ...
    99+
    2024-04-02
  • Java怎么通过递归算法解决迷宫与汉诺塔及八皇后问题
    本篇内容介绍了“Java怎么通过递归算法解决迷宫与汉诺塔及八皇后问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.递归的重要规则在执行一...
    99+
    2023-06-30
  • 【AI】Python 实现八数码问题
    八数码问题 1. 题目介绍 八数码问题描述为:在 3×3 组成的九宫格棋盘上,摆有 8 张牌,每张牌都刻有 1-8 中的某一个数码。棋盘中留有一个空格,允许其周围的某张牌向空格移动,这样通过移动牌就可...
    99+
    2023-10-26
    算法 人工智能
  • Python 概率生成问题案例详解
    概率生成问题 有一枚不均匀的硬币,要求产生均匀的概率分布 有一枚均匀的硬币,要求产生不均匀的概率分布,如 0.25 和 0.75 利用 Rand7() 实现 Rand10() ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作