LintCode N皇后问题 II

题目

根据n皇后问题,现在返回n皇后不同的解决方案的数量而不是具体的放置布局。

样例
比如n=4,存在2种解决方案

代码

class Solution {
    /**
     * Calculate the total number of distinct N-Queen solutions.
     * @param n: The number of queens.
     * @return: The total number of distinct solutions.
     */
    public static int sum;
    public int totalNQueens(int n) {
        sum = 0;
        int[] usedColumns = new int[n];
        placeQueen(usedColumns, 0);
        return sum;
    }
    public void placeQueen(int[] usedColumns, int row) {
        int n = usedColumns.length;
        
        if (row == n) {
            sum ++;
            return;
        }
        
        for (int i = 0; i < n; i++) {
            if (isValid(usedColumns, row, i)) {
                usedColumns[row] = i;
                placeQueen(usedColumns, row + 1);
            }
        }
    }
    public boolean isValid(int[] usedColumns, int row, int col) {
        for (int i = 0; i < row; i++) {
            if (usedColumns[i] == col) {
                return false;
            }
            if ((row - i) == Math.abs(col-usedColumns[i])) {
                return false;
            }
        }
        return true;
    }
};


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,975评论 25 708
  • 美少女我是前旅游行业从业人员,我做的主要的工作就是在节假日来临之前,推荐各种好玩的好吃的地方!让大家赶紧去玩玩玩!...
    5e8e40006a14阅读 611评论 0 8
  • 听的心酸 笑的流泪 慢慢的心瑟 …… 听一首歌 慢慢陪着流泪 …… 经年之后 可还心怀期待…… 安眠 …… 对生活...
    浮华七阅读 162评论 0 0
  • 四月是你的谎言 每一篇总有动人的话语 你在与不在都一样 那就永远在一起吧 春天就要来了 没有你的春天就要来了 那只...
    汐的岛阅读 232评论 0 1
  • 木兰花慢*立春 寒月洒银辉,啼声远,青鸟幽。纵冰河万里,缤纷千鳞,竞把春意了。飞雪梦蝶,又渐渐,绿纹细染池心。风动...
    教育and成长阅读 125评论 0 0