JAVA练习184-八皇后

本文探讨了如何使用DFS和回溯算法解决N皇后问题,确保每个皇后在棋盘上不同行、列和对角线。文章介绍了问题的扩展版,并提供了4皇后问题的两种解法,分析了算法的时间复杂度为O(n!)和空间复杂度为O(n)。
摘要由CSDN通过智能技术生成

设计一种算法,打印 N 皇后在 N × N 棋盘上的各种摆法,其中每个皇后都不同行、不同列,也不在对角线上。这里的“对角线”指的是所有的对角线,不只是平分整个棋盘的那两条对角线。

注意:本题相对原题做了扩展

示例:
 输入:4
 输出:[[".Q..","...Q","Q...","..Q."],["..Q.","Q...","...Q",".Q.."]]
 解释: 4 皇后问题存在如下两个不同的解法。
[
 [".Q..",  // 解法 1
  "...Q",
  "Q...",
  "..Q."],

 ["..Q.",  // 解法 2
  "Q...",
  "...Q",
  ".Q.."]
]

分析:

方法:DFS+回溯

我们可以定义一个数组存储每一行皇后的位置,然后按照行的顺序进行遍历,每遍历一次判断那一行哪些位置能添加皇后,添加后继续遍历下一层,若遍历完成,就记录结果,然后回溯到上一层,继续判断后面的位置是否能添加。

时间复杂度:O(n!)        n 为皇后数量
空间复杂度:O(n)

class Solution {

    //创建棋盘,记录每层皇后的位置
    int[] chess;
    //棋盘边长
    int len;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

什巳

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值