Python八皇后问题

本文阅读 2 分钟
首页 Python笔记 正文

在8*8的国际象棋上摆放八个皇后, 使其不能相互攻击, 即任意两个皇后不得处在同一行, 同一列或者同一对角线上
可以用回溯法, 也可以用下面的判别方法:
由于8各皇后的任意两个不能处在同一行, 那么肯定每一个皇后占据一行。
定义一个数组columnIndex[8], 数组中的第i个数字表示位于第i行的皇后列号
先把数组columnIndex[8]的8个数字分别用0-7初始化, 接下来就是对数组columnIndex的全排列
因为我们使用不同的数字初始化数组,所以任意两个皇后肯定不同列, 只需判断每一个排列对应的8个皇后是不是在一个对角线上
也就是对于下标i和j, 是不是abs(i-j) = columnIndex[i]-columnIndex[j]

  1. class Solution:
  2. # 全排列出所有顶点组合
  3. def Permutation(self, pointArr):
  4. if not len(pointArr):
  5. return []
  6. if len(pointArr) == 1:
  7. return pointArr
  8. numList = pointArr
  9. numList.sort()
  10. pStr = []
  11. for i in range(len(numList)):
  12. if i > 0 and numList[i] == numList[i-1]:
  13. continue
  14. temp = self.Permutation(numList[:i] + numList[i+1:])
  15. if type(temp[0]) == int:
  16. for j in temp:
  17. pStr.append([numList[i]] + [j])
  18. else:
  19. for j in temp:
  20. tempArr = [numList[i]] + j
  21. pStr.append(tempArr)
  22. return pStr
  23. def Judge(self, alist):
  24. length = len(alist)
  25. for i in range(length):
  26. for j in range(length):
  27. if i == j:
  28. continue
  29. if i - j == alist[i] - alist[j] or j - i == alist[i] - alist[j]:
  30. return False
  31. return True
  32. def queen(self, alist):
  33. allAns = self.Permutation(alist)
  34. for tempList in allAns:
  35. isQueen = self.Judge(tempList)
  36. if isQueen:
  37. print(tempList)
  38. s = Solution()
  39. s.queen([0, 1, 2, 3, 4, 5, 6, 7])
解压密码: detechn或detechn.com

免责声明

本站所有资源出自互联网收集整理,本站不参与制作,如果侵犯了您的合法权益,请联系本站我们会及时删除。

本站发布资源来源于互联网,可能存在水印或者引流等信息,请用户自行鉴别,做一个有主见和判断力的用户。

本站资源仅供研究、学习交流之用,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担。

Python二叉搜索树的后续遍历序列
« 上一篇 01-21
Python分治法解决最近对问题
下一篇 » 01-21

发表评论