JAVA学习-练习试用Java实现“N皇后 II”

问题:

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

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

示例 1:

输入:n = 4

输出:2

解释:如上图所示,4 皇后问题存在两个不同的解法。

示例 2:

输入:n = 1

输出:1

提示:

1 <= n <= 9

皇后彼此不能相互攻击,也就是说:任何两个皇后都不能处于同一条横行、纵行或斜线上。

以下程序实现了这一功能,请你填补空白处内容:

java 复制代码
class Solution(object):
    def __init__(self):
        self.count = 0
    def totalNQueens(self, n):
        self.dfs(0, n, 0, 0, 0)
        return self.count
    def dfs(self, row, n, column, diag, antiDiag):
        if row == n:
            self.count += 1
            return
        for index in range(n):
            isColSafe = (1 << index) & column == 0
            isDigSafe = (1 << (n - 1 + row - index)) & diag == 0
            isAntiDiagSafe = (1 << (row + index)) & antiDiag == 0
            if isAntiDiagSafe and isColSafe and isDigSafe:
                _________________________;
if __name__ == '__main__':
    s = Solution()
    print (s.totalNQueens(4))

解答思路:

以下是填补空白处的代码:

java 复制代码
column ^= (1 << index)
diag ^= (1 << (n - 1 + row - index))
antiDiag ^= (1 << (row + index))
self.dfs(row + 1, n, column, diag, antiDiag)

这段代码的作用是在找到一个安全的位置放置皇后后,更新列、对角线和反对角线的状态,并继续进行下一行的搜索。

具体来说,'column ^= (1 << index)' 将列的状态更新为在当前位置放置皇后后的状态。'diag ^= (1 << (n - 1 + row - index))' 和 'antiDiag ^= (1 << (row + index))' 分别更新对角线和反对角线的状态。

然后,通过调用 'self.dfs(row + 1, n, column, diag, antiDiag)' 继续进行下一行的搜索,以寻找下一个安全的位置放置皇后。

这样,通过递归地进行深度优先搜索,并在找到安全位置时更新状态,最终可以得到所有不同的解决方案的数量。

(文章为作者在学习java过程中的一些个人体会总结和借鉴,如有不当、错误的地方,请各位大佬批评指正,定当努力改正,如有侵权请联系作者删帖。)

相关推荐
Tony Bai2 小时前
Go 安全新提案:runtime/secret 能否终结密钥残留的噩梦?
java·开发语言·jvm·安全·golang
oioihoii2 小时前
C++11到C++23语法糖万字详解
java·c++·c++23
pengzhuofan2 小时前
Java演进与与工程师成长
java·开发语言
月明长歌2 小时前
再谈Java 继承与多态:从“能用”到“精通”,更深一层的原理与设计思维
java·开发语言
集3042 小时前
C++多线程学习笔记
c++·笔记·学习
狗头实习生3 小时前
Spring常见的事务失效原因
java·数据库·spring
知南x3 小时前
【正点原子STM32MP157 可信任固件TF-A学习篇】(2) STM32MP1 中的 TF-A
stm32·嵌入式硬件·学习·stm32mp157
YJlio3 小时前
Active Directory 工具学习笔记(10.0):AdExplorer / AdInsight / AdRestore 导读与场景地图
网络·笔记·学习
子夜江寒3 小时前
Python 学习-Day8-执行其他应用程序
python·学习
想个名字太难3 小时前
网络爬虫入门程序
java·爬虫·maven