N-Queens @ LeetCode (Python)
Best Time to Buy and Sell Stock @ LeetCode (Python)

N-Queens II @ LeetCode (Python)

kitt posted @ 2014年3月15日 22:07 in LeetCode , 2008 阅读

这基本上和N-Queens相同。

class Solution:
    # @return an integer
    def totalNQueens(self, n):
        self.res = 0
        self.solve(n, 0, [-1 for i in xrange(n)])
        return self.res
    
    def solve(self, n, currQueenNum, board):
        if currQueenNum == n: self.res += 1; return
        # try to put a Queen in (currQueenNum, 0), (currQueenNum, 1), ..., (currQueenNum, n-1)
        for i in xrange(n):
            valid = True  # test whether board[currQueenNum] can be i or not
            for k in xrange(currQueenNum):
                # check column
                if board[k] == i: valid = False; break
                # check diagonal
                if abs(board[k] - i) == currQueenNum - k: valid = False; break
            if valid:
                board[currQueenNum] = i
                self.solve(n, currQueenNum + 1, board)

登录 *


loading captcha image...
(输入验证码)
or Ctrl+Enter