`

Leetcode - N-Queens

 
阅读更多
[分析] N皇后摆放规则:两个皇后不能共存于同一行、同一列以及同一(斜率为1的)斜线上。rows 数组用于记录每行的皇后所摆放的列位置,并用于构造结果;cols数组记录该列为哪个皇后的地盘,两个数组共同完成回溯过程。

public class Solution {
    public List<List<String>> solveNQueens(int n) {
        int[] rows = new int[n]; // rows[i] = j, means board[i][j] = Q
        int[] cols = new int[n]; // cols[j] = i, means board[i][j] = Q
        for (int i = 0; i < n; i++) {
            rows[i] = -1;
            cols[i] = -1;
        }
        List<List<String>> result = new ArrayList<List<String>>();
        recur(n, 0, rows, cols, result);
        return result;
    }
    
    public void recur(int n, int r, int[] rows, int[] cols, List<List<String>> result) {
        if (r == n) {
            List<String> oneSolution = new ArrayList<String>();
            StringBuilder rowstr = new StringBuilder(n);
            for (int i = 0; i < n; i++) {
                rowstr.delete(0, n);
                for (int j = 0; j < n; j++) {
                    if (rows[i] != j)
                        rowstr.append('.');
                    else
                        rowstr.append('Q');
                }
                oneSolution.add(rowstr.toString());
            }
            result.add(oneSolution);
            return;
        }
        for (int j = 0; j < n; j++) {
            if (cols[j] == -1 && verifyDiagnal(rows, r, j)) {
                rows[r] = j;
                cols[j] = r;
                recur(n, r + 1, rows, cols, result);
                rows[r] = -1;
                cols[j] = -1;
            }
        }
    }
    
    public boolean verifyDiagnal (int[] rows, int r, int c) {
        for (int i = 0; i < r; i++) {
            if (r - i == Math.abs(c - rows[i]))
                return false;
        }
        return true;
    }
}
分享到:
评论

相关推荐

    _leetcode-python.pdf

    - N-Queens / N-Queens II: 第一个问题是经典的N皇后问题,要求在一个N×N的棋盘上放置N个皇后,使得它们互不攻击;第二个问题则是对第一个问题的求解数的计数。 - Maximum Subarray: 寻找一个整数数组中,连续子...

    js-leetcode题解之52-n-queens-II.js

    对于"52-n-queens-II.js"这一特定的实现,我们主要关注的是52题的变体,即如何计算出所有可能的解,而不仅仅是返回任意一个解。 在实现这个问题的解决方案时,通常会用到回溯算法。回溯算法是一种通过递归来穷举...

    js-leetcode题解之51-n-queens.js

    8. JavaScript语言特性:在编写js-leetcode题解之51-n-queens.js时,需要利用JavaScript语言的数组、循环、条件判断以及递归等特性。 9. 功能测试:在算法实现完成后,需要编写测试用例来验证算法的正确性。测试时...

    leetcode怎么销号-LeetCode-Solutions:我自己的LeetCode解决方案

    leetcode怎么销号 LeetCode-Solutions :green_heart:My ...N-Queens Hard 回溯 0053 Maximum Subarray Easy 动态规划 0069 Sqrt(x) Easy 二分、牛顿迭代 0070 Climbing Stairs Easy 动态规划 0075 Sort Colors M

    leetcode怎么计算空间复杂度是指-LeetCode-Solution:我的第一个LeetCode解决方案

    051:N-Queens 052:N-Queens II 071: Letter Combinations of a Phone Number 093:Restore IP Addresses 树的遍历问题也可以用这种思想来解释。只不过是特殊的递归而已。(只有两路,不用循环) 题型二:动态规划...

    leetcode推箱子放进进仓库-Leetcode-May-Challenge-2021:它包含LeetcodeMayChallenge202

    leetcode 推开箱子进深 Leetcode-May-Challenge-2021 它包含 Leetcode May Challenge 2021 的解决方案 比赛链接: 问题 问题名称 点击打开问题 无向图中的连通分量数 ...N-皇后 ...N-Queens II 最大差距 搜索建议系统

    LeetCode-js:用 JavaScript 解决 LeetCode 问题

    4. **回溯**:回溯是一种解决约束满足问题的算法,常用于“组合总和”(Combination Sum)、“N 皇后问题”(N-Queens)等。JavaScript 中回溯算法往往结合递归来实现。 5. **动态规划**:动态规划是解决优化问题的...

    leetcode答案-LeetCode-and-At-Offer:LeetCode即买即卖

    leetcode ...NQueens * 回溯法- 网易2017算法工程师笔试题3 * 贪心法- Dijkstra算法 ShortestDistanceAlgorithm * 动态规划- Floyd最短路径算法 ShortestDistanceAlgorithm * 动态规划- 最长公共子序列 ...

    javalruleetcode-leetcode-oo:我使用面向对象设计的leetcode实现

    N 个节点 中等的 20 有效括号 简单的 21 合并两个排序列表 简单的 22 生成括号 中等的 23 合并 k 个排序列表 难的 26 从排序数组中删除重复项 简单的 27 删除元素 简单的 30 连接所有单词的子串 难的 32 最长有效...

    leetcode530-leetcode-practice:练习力码

    leetcode 530 力码练习 前 250 个问题 1 二和 :check_mark: 3 无重复字符的最长子串 :check_mark: 4 两个有序数组的中位数 5 最长回文子串 7 反转整数 8 字符串到整数 (atoi) 10 正则表达式匹配 11 盛水的容器 12 ...

    leetcode71python-leetcode:leetcode

    leetcode 71 Python用 Python 编写 Leetcode (数据科学家的解决方案) - 易于理解的最佳解决方案,可以通过所有 Leetcode 测试用例,对于非 ...leetcode ...leetcode ...N-Queens (HARD) Leetcode 52. N-

    Leetcode-best-DSA-问题:必须执行这些leetcode编码问题以提高您的问题解决能力

    如“N皇后问题”(N-Queens)和“字母异位词”(Anagram)。 7. **图和树**:树和图的数据结构广泛应用于计算机科学的各个领域。如“二叉树的最近公共祖先”(Lowest Common Ancestor of a Binary Tree)和“拓扑...

    最大公共字符串leetcode-LeetCodeSolultionBook:力码解决方案书

    最大公共字符串leetcode 这本书的在线版本可以在 [gitbook.com] 上查看 进步写作 104 二叉树的最大深度 111 二叉树的最小深度 174 地牢游戏 84 直方图中最大的矩形 85 最大矩形 198 强盗 第213话 第42章 截留雨水 11...

    LeetCode-Java

    5. **回溯法和递归**:在解决组合问题和路径寻找问题时,如"N-Queens",回溯法和递归是常用的技术。 6. **图论**:虽然LeetCode上的图问题相对较少,但依然有如"Course Schedule"这样的问题,涉及拓扑排序和深度...

    多线程leetcode-PracticeProblems:C++练习题测试数据结构,学习新工具,解决常见问题

    nQueens 算法的优化实现。 它使用 3 个无符号 64 位整数来存储棋盘上皇后的位置:一个存放所有列的位置,两个存放对角线方向的皇后位置。 检查皇后是否已经在某个位置是一个简单的过程,需要最少的过程:简单地将...

    颜色分类leetcode-mlrose:用于实现许多机器学习、随机优化和搜索算法的Python包

    N-Queens 和背包问题; 连续值优化问题,如神经网络权重问题; 和旅游优化问题,例如旅行商问题。 它还具有解决用户定义的优化问题的灵活性。 在开发时,不存在将所有这些功能集中在一个位置的单个 Python 包。 主要...

    leetcode分类-LeetCode:力码

    leetcode 分类 LeetCode Progress 128/154 Other Solutions C++,有详细思路解释 python,部分有解释 Java,部分有解释 ...norvig神牛Python代码写的很飘逸,果然是有LISP...N-Queens N-Queens II Balanced Binary Tree Binar

    lrucacheleetcode-leetcode:个人刷leetcode遇到的一些题汇总(golang)

    比如n-queens-ii对应链接为: 题目 url add-two-numbers find-peak-element longest-common-subsequence longest-consecutive-sequence max-area-of-island next-greater-element-ii serialize-and-deserialize-...

    leetcode530-LeetCode:力码

    leetcode ...N-Queens II 最大子阵列 螺旋矩阵 跳跃游戏 合并间隔 插入间隔 螺旋矩阵 II 排列顺序(无法访问文章) 61-70 轮换名单 独特的路径 独特的路径 II 最小路径和(无法访问文章) 有效号码 加一

Global site tag (gtag.js) - Google Analytics