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 )