`
frank-liu
  • 浏览: 1682267 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

leetcode: N-Queens II

 
阅读更多

问题描述:

Follow up for N-Queens problem.

Now, instead outputting board configurations, return the total number of distinct solutions.

 

原问题链接:https://leetcode.com/problems/n-queens-ii/

 

问题分析

  这个问题和前面的问题基本上一样,无非是不需要保存它的所有位置信息,只需要记录它有多少个布局而已。所以只需要做一点小的改变。在递归函数里定义一个List,每次结束的时候在List里加一个元素。这样到执行结束的时候返回List的长度就可以了。

 

public class Solution {
    public int totalNQueens(int n) {
        int[] list = new int[n];
        List<Integer> result = new ArrayList<Integer>();
        search(0, list, result);
        return result.size();
    }
    
    public void search(int index, int[] list, List<Integer> result) {
        if(index == list.length) {
            result.add(1);
            return;
        }
        for(int i = 0; i < list.length; i++) {
            list[index] = i;
            if(match(list, index))
                search(index + 1, list, result);
        }
    }
    
    boolean match(int[] a, int i) {
        for(int j = 0; j < i; j++) {
            if(a[j] == a[i] || Math.abs(a[j] - a[i]) == Math.abs(j - i))
                return false;
        }
        
        return true;
    }
}

 

 

  • 大小: 8.2 KB
分享到:
评论

相关推荐

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

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

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

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

    leetcode71python-leetcode:leetcode

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

    leetcode分类-LeetCode:力码

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

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

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

    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-...

    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-May-Challenge-2021:它包含LeetcodeMayChallenge202

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

    leetcode530-LeetCode:力码

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

    leetcode中国-Leetcode:Leetcode的生活经历:)

    leetcode中国力码 我的 Leetcode 生活经历! 我创建了这个存储库来分享我对 leetcode 问题的解决方案。 另外,我会补充一下我在解决问题时的想法,也会补充一些简单的测试用例以供...N-Queens(硬) 56. 合并间隔(中)

    leetcode题库-LeetCode:LeetCode题库>算法

    - **回溯法**:尝试所有可能的解决方案,如八皇后问题、N-Queens、排列组合等。 - **分治法**:将问题分解为较小的子问题,如快速排序、归并排序、大整数乘法等。 - **递归**:函数自我调用,解决树形结构或多...

    leetcode分类-Leetcode:练习编码面试问题

    N-Queens II 平衡二叉树 二叉树中序遍历 二叉树最大路径和 将排序数组转换为二叉搜索树 将排序列表转换为二叉搜索树 将二叉树展平到链表 二叉树的最大深度 二叉树的最小深度 路径和 排列 排列二 在每个节点中填充下...

    leetcode530-leetcode:我的leetcode解决方案

    leetcode 530 leetcode 我对 leetcode 的解决方案。 使用c++解决问题。 # 标题 解决方案 标签 方法 1185 一周中的天 大批 5499 检测长度模式重复 k 次或多次 大批 ...n-queens-ii DFS,搜索 1003 替

    leetcode分类-leetcode:leetcode刷题(中等难度分类)

    1. 回溯法:中等难度题目中,回溯法是一种常见的解决方案,如"Combination Sum"(组合总和)和"N-Queens"(皇后问题),通过回溯可以找到所有可能的解。 2. 动态规划:"House Robber"(打家劫舍)系列问题,展示了...

    leetcode530-leetcode-practice:练习力码

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

    leetcode力扣是什么-leetcode:leetcodebytags按自己整理的一些类别

    leetcode力扣是什么 leetcode-按类别 看了一些leetcode刷题指南,总结一下两个重点,一是...N-Queens (hard) 132 Palindrome Partitioning (hard) 212 Word Search II (hard) DFS /二叉树 the difference between df

    Leetcode:更大的LeetcodeLösungen

    49组Anagrams视频讲解50 Pow(x,n)视频讲解51 N-Queens视频讲解52 N-Queens II视频讲解53最大子数组视频讲解54螺旋矩阵视频讲解55跳转游戏视频讲解56合并间隔视频讲解57插入间隔视频讲解59螺旋矩

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

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

    leetcode2sumc-PlayLeetCode:力扣培训

    leetcode 2 和 c PlayLeetCode 基于c++的LeetCode训练 尖端: 单击问题的Number (#) 单击Solution ([00xx-Solution]) 到解决方案 # 标题 困难 方法 解决方案 ...N ...组合和II ...N-皇后 ...N-Queens II 难的

    javalruleetcode-leetcode:我对leetcode挑战的解决方案

    N-Queens II 59.44% 97 交错串 TLE 146 LRU缓存 83.44% 174 地牢游戏 100% 的 Go 提交 354 俄罗斯娃娃信封 23.99% 中等评价 数量 问题 殴打 2 添加两个数字 35.18% 3 无重复字符的最长子串 79.27% 5 最长回文子串 87...

Global site tag (gtag.js) - Google Analytics