【LeetCode with Python】 N-Queens

博客域名: http://www.xnerv.wang
原题页面: https://oj.leetcode.com/problems/n-queens/
题目类型:
难度评价:★
本文地址: http://blog.csdn.net/nerv3x3/article/details/39453349

The n-queens puzzle is the problem of placing n queens on ann×n chessboard such that no two queens attack each other.


Given an integer n, return all distinct solutions to the n-queens puzzle.

Each solution contains a distinct board configuration of the n-queens' placement, where'Q' and '.' both indicate a queen and an empty space respectively.

For example,
There exist two distinct solutions to the 4-queens puzzle:

[
 [".Q..",  // Solution 1
  "...Q",
  "Q...",
  "..Q."],

 ["..Q.",  // Solution 2
  "Q...",
  "...Q",
  ".Q.."]
]


class Solution:

    def __init__(self):
        self.paths = [ ]

    def dpSolveNQueens(self, n, prefix, level):
        for i in range(0, n):
            point = (i, level)
            is_valid = True
            for m in range(0, len(prefix)):
                if i == prefix[m]:
                    is_valid = False
                    break
                if level - m == i - prefix[m] or level - m == prefix[m] - i:
                    is_valid = False
                    break
            if is_valid:
                new_prefix = prefix[:]
                new_prefix.append(i)
                if n - 1 != level:
                    self.dpSolveNQueens(n, new_prefix, level + 1)
                else:
                    self.paths.append(new_prefix)

    # @return a list of lists of string
    def solveNQueens(self, n):
        self.dpSolveNQueens(n, [ ], 0)
        lists = [ ]
        for path in self.paths:
            list = [ ]
            for num in path:
                str = "." * num + "Q" + "." * (n - num - 1)
                list.append(str)
            lists.append(list)
        return lists

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值