V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
yukaze18
V2EX  ›  问与答

小白求解八皇后问题的生成器函数问题

  •  
  •   yukaze18 · Apr 8, 2018 via Android · 2040 views
    This topic created in 2955 days ago, the information mentioned may be changed or developed.

    def queens(num=8, state=()): # 生成器函数 for pos in range(num): if not conflict(state, pos): # 到达最后一行时返回(pos,) if len(state) == num - 1: yield (pos,) # 只有一个元素的元组 else: for result in queens(num, state + (pos,)): # result 在返回的生成器中迭代 yield (pos,) + result

    这个是如何实现回溯算法的,比如说到了( 0.2.4.1.3 )之后发现没有位置可以放,怎么退回到上一步变成( 0.2.4.1.7 )

    3 replies    2018-04-09 10:36:58 +08:00
    aheadlead
        1
    aheadlead  
       Apr 8, 2018
    https://gist.github.com/

    用这个贴代码,格式比较好,要不没人愿意读这样的代码
    yemenchun1
        2
    yemenchun1  
       Apr 8, 2018 via iPhone
    else 后面递归调用 queens 函数了
    fromxt
        3
    fromxt  
       Apr 9, 2018
    这好像是《 python 基础教程》的一个例子吧。
    回溯算法我是这么理解的。例如只有 4 个皇后 ( num=4 )
    记住是从 pos=0 开始,第 1 个皇后的位置就有 0,1, 2, 3 这四个可能.
    从 pos =0 开始,通过 conflict(state, pos)函数,判断满足条件的第 2 个皇后的位置,然后第 3 个,第 4 个。这就找到了满足条件的位置。这时候就是会退到 pos =1 的位置,然后按照前面的流程走。
    if len(state) == num - 1 这个就是前三个皇后位置已经确定了 找最后一个皇后位置。
    反复读读那本书第 9 章第 8 节,^_^应该好理解了。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2897 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 44ms · UTC 15:27 · PVG 23:27 · LAX 08:27 · JFK 11:27
    ♥ Do have faith in what you're doing.