题目描述(困难难度)

和一样,只不过这次不需要返回所有结果,只需要返回有多少个解就可以。

解法一

我们直接把上道题的 ans 的 size 返回就可以了,此外 currentQueen.size ( ) == n 的时候,也不用去生成一个解了,直接加一个数字占位。

时间复杂度:

空间复杂度:

解法二

参考这里)。

由于没有了 currentQueen,所有不能再用之前 isDiagonalAttack 判断对角线冲突的方法了。我们可以观察下,对角线元素的情况。

可以发现对于同一条副对角线,row + col 的值是相等的。

对于同一条主对角线,row - col 的值是相等的。

我们同样可以用一个 bool 型数组,来保存当前对角线是否有元素,把它们相加相减的值作为下标。

  1. List<Integer> ans = new ArrayList<>();
  2. boolean[] cols = new boolean[n]; // 列
  3. boolean[] d1 = new boolean[2 * n]; // 主对角线
  4. boolean[] d2 = new boolean[2 * n]; // 副对角线
  5. return backtrack(0, cols, d1, d2, n, 0);
  6. }
  7. private int backtrack(int row, boolean[] cols, boolean[] d1, boolean[] d2, int n, int count) {
  8. count++;
  9. } else {
  10. for (int col = 0; col < n; col++) {
  11. int id1 = row - col + n; //主对角线加 n
  12. int id2 = row + col;
  13. if (cols[col] || d1[id1] || d2[id2])
  14. continue;
  15. cols[col] = true;
  16. d2[id2] = true;
  17. count = backtrack(row + 1, cols, d1, d2, n, count);
  18. cols[col] = false;
  19. d1[id1] = false;
  20. d2[id2] = false;
  21. }
  22. }
  23. }

时间复杂度:

空间复杂度:

和上一题相比,通过三个 bool 型数组来标记是否占有,不存储具体的位置,从而解决了这道题。

windliang wechat

添加好友一起进步~

如果想系统的学习数据结构和算法,强烈推荐一个我之前学过的课程,可以点击 这里 查看详情