生成器应用

2015-11-30 0 675
生成器应用
def conflict(state,nextX):
    nextY=len(state)
    for i in range(nextY):
        if abs(state[i]-nextX) in (0,nextY-i):
            return True
    return False
def queues(num=8,state=()):
    for pos in range(num):
        if not conflict(state,pos):
            if len(state)==num-1:
                yield (pos,)
            else:
                for result in queues(num,state+(pos,)):
                    yield (pos,)+result
def preatprint(solution):
    def lines(pos,length=len(solution)):
        return '. '*(pos)+'x '+'. '*(length-pos-1)
    for pos in solution:
        print lines(pos)
        
if __name__=='__main__':
   
     import random
     preatprint(random.choice(list(queues(8))))

遇见资源网 python 生成器应用 http://www.ox520.com/16001.html

上一篇: 解密
常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务