leetcode_52. N 皇后 II

52. N 皇后 II

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

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

示例 1:

复制代码
输入:n = 4
输出:2
解释:如上图所示,4 皇后问题存在两个不同的解法。

示例 2:

复制代码
输入:n = 1
输出:1

提示:

  • 1 <= n <= 9

代码思路:

backtrack(int n, int index):

  • index 表示++当前正在处理的行号++。
  • 如果 index 等于或超过 n,说明所有行都成功放置了皇后,找到一个符合条件的方案,res 增加 1;否则,尝试在当前行的每一列放置皇后。每放置一个皇后时,调用 judge(int x, int y) 检查是否安全。
  • 如果 judge 返回 true,表示当前列是安全的,将该列号添加到 cur,并继续递归处理下一行。
  • 递归完成后,移除刚放置的皇后(即回溯),继续尝试放置在其他列。

judge(int x, int y):

  • 用于判断++当前行 x,列 y 是++否安全。
  • 检查之前的每一行 j 中的皇后位置 ny = cur.get(j);如果 ny == y,说明当前列有冲突。如果 Math.abs(ny - y) == Math.abs(j - x),说明在对角线上有冲突。
  • 如果都不冲突,返回 true,表示当前位置安全。

回溯算法通过尝试在每一行的每一列放置皇后,并通过递归处理后续行来探索所有可能的放置方案。judge 方法用于在放置之前检查是否会产生冲突。最终 res 记录了所有合法的方案数量。

java 复制代码
class Solution {
    Integer res = 0;
    LinkedList<Integer> cur = new LinkedList<>();

    public int totalNQueens(int n) {
        backtrack(n, 0);
        return res;
    }

    public void backtrack(int n, int index) {
        if (index >= n) {
            res++;
            return;
        }

        for (int i = 0; i < n; i++) {
            if (judge(index, i)) {
                cur.add(i);
                backtrack(n, index + 1);
                cur.removeLast();

            }
        }

    }

    public Boolean judge(int x, int y) {
        for (int j = 0; j < x; j++) {
            int ny = cur.get(j);
            if (ny == y || Math.abs(ny - y) == Math.abs(j - x)) {
                return false;
            }
        }
        return true;
    }
}
相关推荐
SsummerC1 分钟前
【leetcode100】杨辉三角
python·leetcode·动态规划
杰杰批2 分钟前
力扣热题100——普通数组(不普通)
算法·leetcode
CodeSheep2 分钟前
稚晖君又添一员猛将!
人工智能·算法·程序员
天天扭码4 分钟前
一分钟解决“3.无重复字符的最长字串问题”(最优解)
前端·javascript·算法
风靡晚9 分钟前
一种改进的CFAR算法用于目标检测(解决多目标掩蔽)
人工智能·算法·目标检测·目标跟踪·信息与通信·信号处理
香宝的最强后援XD23 分钟前
区域填充算法
算法
guitarCC30 分钟前
【裁员感想】
职场和发展
所以遗憾是什么呢?41 分钟前
扩展欧几里得算法【Exgcd】的内容与题目应用
数学·算法·数论·扩展欧几里得·exgcd
haaaaaaarry1 小时前
【贪心】C++ 活动安排问题
开发语言·c++·算法·贪心
ChengZUOZZZ1 小时前
蓝桥杯题目:二维前缀和
java·算法·蓝桥杯