利用python 完成leetcode51 N皇后

n皇后问题探讨如何在n×n棋盘上放置皇后,使得皇后彼此不攻击。本文介绍了使用回溯法解决8皇后问题的思路和Python实现,展示了不同解法的棋子布局。
摘要由CSDN通过智能技术生成

n 皇后问题研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击。

在这里插入图片描述
上图为 8 皇后问题的一种解法。

给定一个整数 n,返回所有不同的 n 皇后问题的解决方案。

每一种解法包含一个明确的 n 皇后问题的棋子放置方案,该方案中 ‘Q’ 和 ‘.’ 分别代表了皇后和空位。

示例:

输入: 4
输出: [
[".Q…", // 解法 1
“…Q”,
“Q…”,
“…Q.”],

["…Q.", // 解法 2
“Q…”,
“…Q”,
“.Q…”]
]
解释: 4 皇后问题存在两个不同的解法。
思路
经典问题,回溯法,首先设置第1个棋子的位置,然后递归的设置下一个棋子的位置,如果棋子无地可放,则将上一个棋子的位置移动,如果n个棋子全部成功放置,则将当前结果添加到最终结果
代码

def solveNQueens(self, n):
        l=[0]*n#储存每个棋子的位置
        e=[]
        for i in range(n):#统计将第一个棋子放在第i个位置的所有情况
            l[0]=i
            self.f(l,n,1,e)
        return e
    def f(self,l,n,k,e):
        if k==n:#将成功结果添加至最终结果
            q=[]
            for i in l:
                s='.'*i+'Q'+(n-i-1)*'.'
                q.append(s)
            e.append(q)
            return 
    
        for i in range(n):
            u=0
            for c in range(k):
                if(l[c]==i or l[c]-c==i-k or l[c]-k==i-c ):#检测能否放置,分别是竖,左上到右下,右上到左下
                    u=1
                    break
            if(u==0):
                l[k]=i
                self.f(l,n,k+1,e)#能放的话,放置下一个棋子
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值