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

八皇后问题(Python)

python开发语言算法 2023-09-29 20:09:39 692人浏览 独家记忆

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

摘要

一.问题简介 八皇后问题: 如何能在 8*8 的国际象棋棋盘上放置八个皇后,使得任何一个皇后都无法直接吃掉其他的皇后?为了到达此目的,任两个皇后都不能处于同一条横行、纵行或斜线上。 二.几种思路和方法 1.回溯法+递归思想  如图所示,圆

一.问题简介

八皇后问题: 如何能在 8*8 的国际象棋棋盘上放置八个皇后,使得任何一个皇后都无法直接吃掉其他的皇后?为了到达此目的,任两个皇后都不能处于同一条横行、纵行或斜线上。

二.几种思路和方法

1.回溯法+递归思想

 如图所示,圆圈代表皇后所放的位置,这里如果将棋盘转化为二维矩阵进行遍历比较麻烦,考虑到棋盘的每一行不能同时存在一个以上的皇后,所以将棋盘转化为一个具有八个元素的列表,而皇后的位置(i,j)对应的是列表中(元素的索引值,元素的值),因此放置皇后的操作变成了在列表中的每个位置填值操作,很明显的一个条件是列表中不能有相同的值。图中给出的是某一种情形

接下来直接看代码:

首先是定义一个queen函数,作用就是用来放皇后的位置。然后进入到第一个判断条件:如果当前行的位置遍历到“第9行”,即全部遍历完之后,将所有的结果放入到列表list中;然后是进入循环,在每一行的八个列的位置遍历,如果满足check中所有条件,那么直接递归调用,进入下一行遍历。

check函数:【任两个皇后都不能处于同一条横行】这一条件已经在前面保证成立了,这里只需保证剩下的两个条件【同一条纵行】和【同一条斜线】成立即可。注意:当两个皇后的位置坐标的连线斜率的绝对值为1,则这两个皇后在同一直线上。

def check(self, list, row):        for i in range(row):            if list[i] == list[row] or abs(list[row] - list[i]) == abs(row - i):                return False        return Truedef queen(self, list, row, n):  # list为存储的结果;row是当前行;n为棋盘大小        x=[]        if row == n:            x.extend(list)            self.solves.append(x)            return        for i in range(n):  # 这里的i指的是所在列的值            list[row] = i            if self.check(list, row):                self.queen(list, row + 1, n)

下面是完整代码:

导包:

import numpy as np           # 提供维度数组与矩阵运算import copy                  # 从copy模块导入深度拷贝方法from board import Chessboard

棋盘类的初始化

# 初始化8*8八皇后棋盘chessboard = Chessboard()

# 基于棋盘类,设计搜索策略class Game:    def __init__(self, show = True):        """        初始化游戏状态.        """                self.chessBoard = Chessboard(show)        self.solves = []        self.gameInit()            # 重置游戏    def gameInit(self, show = True):        """        重置棋盘.        """                self.Queen_setRow = [-1] * 8        self.chessBoard.boardInit(False)                    def check(self, list, row):        for i in range(row):            if list[i] == list[row] or abs(list[row] - list[i]) == abs(row - i):                return False        return True    def queen(self, list, row, n):  # list为存储的结果;row是当前行;n为棋盘大小        x=[]        if row == n:            x.extend(list)            self.solves.append(x)            return        for i in range(n):  # 这里的i指的是所在列的值            list[row] = i            if self.check(list, row):                self.queen(list, row + 1, n)        def run(self, row=0):        #self.solves.append([0, 6, 4, 7, 1, 3, 5, 2])        n = 8        list = [0 for _ in range(n)]        self.queen(list,row,n)                def showResults(self, result):        """        结果展示.        """                self.chessBoard.boardInit(False)        for i,item in enumerate(result):            if item >= 0:                self.chessBoard.setQueen(i,item,False)                self.chessBoard.printChessboard(False)        def get_results(self):        """        输出结果.        return: 八皇后的序列解的list.        """                self.run()        return self.solves   

验证一下结果:

game = Game()solutions = game.get_results()print('There are {} results.'.fORMat(len(solutions)))game.showResults(solutions[0])

 可以直接输出所有的结果(92种):

print(solutions)

2.排列组合的思想

在上面的基础上,可以稍微转化一下思路,放置不同的皇后位置就是将不同的八个元素的作排列组合问题,然后只要再保证“不在同一斜线”这个条件就可以了。下面是代码:

list1=[0,1,2,3,4,5,6,7]result=[]final_result=[]from itertools import  permutations  #permutations函数:可以对集合字符串进行排序或排列的所有可能的组合for i in permutations(list1,8):          result.append(i)               #转化为排列组合问题,result存储部分可能的结果      #下面只需要从result中找出满足‘任一两个皇后不在同一斜线上’的结果for i in result:    n=0                  #n用以标记那些满足条件的结果;    for j in enumerate(i):        for m in enumerate(i):            if  m!=j and abs(m[0]-j[0])==abs(m[1]-j[1]):  #m!=j是避免对同一个坐标位置进行判断                n+=1           #只要有两个坐标的连线斜率为1,n就不为0    if n==0:        final_result.append(i)                    print(len(final_result))print(final_result)

3.遗传算法

基本原理和步骤   

        遗传算法将要解决的问题模拟成一个生物进化的过程,通过复制、交叉、突变等操作产生下一代的解,并逐步淘汰掉适应度函数值低的解,增加适应度函数值高的解。这样进化N代后就很有可能会进化出适应度函数值很高的个体。

其计算步骤如下:

(1) 编码:将问题空间转换为遗传空间;

(2)创建初始种群:随机生成P 个染色体作为初始种群;

(3)适应度计算:染色体评价,计算各个染色体的适应度;

(4)选择操作:根据染色体适应度,按选择算子进行染色体的选择;

(5)交叉操作:按交叉概率进行交叉操作;

(6)变异操作:按变异概率进行变异操作;

(7)返回(4)形成新的种群,继续迭代,直到满足终止条件。

 

具体实现代码部分还在写,以后有机会在续上吧。

觉得不错的话,大家给个关注给个赞吧!

来源地址:https://blog.csdn.net/m0_46366547/article/details/127292090

--结束END--

本文标题: 八皇后问题(Python)

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

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

猜你喜欢
  • 八皇后问题(Python)
    一.问题简介 八皇后问题: 如何能在 8*8 的国际象棋棋盘上放置八个皇后,使得任何一个皇后都无法直接吃掉其他的皇后?为了到达此目的,任两个皇后都不能处于同一条横行、纵行或斜线上。 二.几种思路和方法 1.回溯法+递归思想  如图所示,圆...
    99+
    2023-09-29
    python 开发语言 算法
  • 八皇后问题(python 生成器)
    问题: 在8×8格的国际象棋上摆放八个皇后,使其不能互相***,即任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。大致是下面这种样式: 思路: 第一步:皇后位置存放问题 用列表或元组表示。索引表示皇后所在的横行。列表的值...
    99+
    2023-01-31
    生成器 皇后 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序列
    序列是Python中的重要数据结构,序列包括字符串,列表,元组。大部分读者朋友学习Python的时候都会找本书或者资料从头看到尾,这次我们换一个思路,问答式的方式,可能让我们精力更集中,下面开始我们的提问: 1.什么是序列? 序列是将元素...
    99+
    2023-01-31
    序列 十八问 Python
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作