鱼C论坛

 找回密码
 立即注册
查看: 2016|回复: 7

[已解决]八皇后的递归求注释(每段都要,超详细!)

[复制链接]
发表于 2019-9-19 10:20:50 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
尽量详细,谢谢!以下是代码
def bhh1(s,x):
    y = len(s)
    for i in range(y):
        if abs(s[i]-x) in (0,y-i):
            return False
    return True
def bhh2(nums = 8,s = ()):
    for y in range(nums):
        if bhh1(s,y):
            if len(s) == nums - 1:
                yield(y,)
            else:
                for j in bhh2(nums,s+(y,)):
                    yield(y,) + j

print(list(bhh2(4)))
最佳答案
2019-9-19 16:09:32
  1. def bhh1(s,x):
  2.     '''
  3.     s->皇后列位置元组
  4.     x->当前皇后位置
  5.     '''
  6.     y = len(s) #已经放置的皇后个数
  7.     for i in range(y):
  8.         if abs(s[i]-x) in (0,y-i): #逐一取出已经确认的皇后位置,当前位置不能与之在同一列及两对角线上(abs绝对值)
  9.             return False
  10.     return True

  11. def bhh2(nums = 8,s = ()):
  12.     for y in range(nums):
  13.         if bhh1(s,y):
  14.             if len(s) == nums - 1:#最后一个皇后位置选定
  15.                 yield(y,) #返回当前位置的结果元组
  16.             else:
  17.                 for j in bhh2(nums,s+(y,)):
  18.                     yield(y,) + j #返回当前位置和下一个符合条件的皇后的位置的结果元组

  19. print(list(bhh2(4)))
复制代码


个人理解,不喜勿喷,建议看下回溯算法
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-9-19 15:30:45 | 显示全部楼层
我就想围观看看
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-9-19 16:09:32 | 显示全部楼层    本楼为最佳答案   
  1. def bhh1(s,x):
  2.     '''
  3.     s->皇后列位置元组
  4.     x->当前皇后位置
  5.     '''
  6.     y = len(s) #已经放置的皇后个数
  7.     for i in range(y):
  8.         if abs(s[i]-x) in (0,y-i): #逐一取出已经确认的皇后位置,当前位置不能与之在同一列及两对角线上(abs绝对值)
  9.             return False
  10.     return True

  11. def bhh2(nums = 8,s = ()):
  12.     for y in range(nums):
  13.         if bhh1(s,y):
  14.             if len(s) == nums - 1:#最后一个皇后位置选定
  15.                 yield(y,) #返回当前位置的结果元组
  16.             else:
  17.                 for j in bhh2(nums,s+(y,)):
  18.                     yield(y,) + j #返回当前位置和下一个符合条件的皇后的位置的结果元组

  19. print(list(bhh2(4)))
复制代码


个人理解,不喜勿喷,建议看下回溯算法

评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +3 收起 理由
18861950621 + 5 + 5 + 3

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-9-19 16:35:40 | 显示全部楼层
yuweb 发表于 2019-9-19 16:09
个人理解,不喜勿喷,建议看下回溯算法

谢谢,但我还是很懵,至于回溯算法。。。有链接么,我没学到过
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-9-19 16:44:18 | 显示全部楼层
感觉这个太浓缩了,呃,精华,不好理解的话你可以看看其他代码写的
https://baike.baidu.com/item/%E5 ... 2426&fr=aladdin

回溯算法
https://baike.baidu.com/item/%E5 ... 97%E6%B3%95/9258495
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-9-19 21:48:53 | 显示全部楼层
这……要求有点过分
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-9-20 11:00:07 | 显示全部楼层
yuweb 发表于 2019-9-19 16:44
感觉这个太浓缩了,呃,精华,不好理解的话你可以看看其他代码写的
https://baike.baidu.com/item/%E5%85% ...

3Q
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-9-20 11:01:49 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2026-2-5 18:06

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表