问题描述

843. n-皇后问题
n−皇后问题是指将 n 个皇后放在 n×n 的国际象棋棋盘上,使得皇后不能相互攻击到,即任意两个皇后都不能处于同一行、同一列或同一斜线上。
八皇后 - 图1
现在给定整数 n,请你输出所有的满足条件的棋子摆法。
输入格式
共一行,包含整数 n。
输出格式
每个解决方案占 n 行,每行输出一个长度为 n 的字符串,用来表示完整的棋盘状态。
其中 . 表示某一个位置的方格状态为空,Q 表示某一个位置的方格上摆着皇后。
每个方案输出完成后,输出一个空行。
注意:行末不能有多余空格。
输出方案的顺序任意,只要不重复且没有遗漏即可。
数据范围
1≤n≤9
输入样例:

  1. 4

输出样例:

  1. .Q..
  2. ...Q
  3. Q...
  4. ..Q.
  5. ..Q.
  6. Q...
  7. ...Q
  8. .Q..

思路

与组合问题类似,找到一种能遍历所有情况的方法。
方法一按格子遍历,最大深度为n*n
方法二按行遍历,最大深度为n
可见不同的遍历顺序效果也不尽相同。

注意:在dfs过程中存储中间状态和结果。

方法一

  1. import java.util.*;
  2. public class Main {
  3. static int n;
  4. static char[][] g;
  5. static int[] row, col, dg, udg;
  6. public static void main(String[] args) {
  7. Scanner sc = new Scanner(System.in);
  8. n = sc.nextInt();
  9. g = new char[n][n];
  10. col = new int[n];
  11. row = new int[n];
  12. dg = new int[2 * n];
  13. udg = new int[2 * n];
  14. for (int i = 0; i < n; i++) {
  15. Arrays.fill(g[i], '.');
  16. }
  17. dfs(0, 0, 0);
  18. }
  19. static void dfs(int x, int y, int sum) {
  20. if (y == n) {
  21. y = 0;
  22. x++;
  23. }
  24. if (x == n) {
  25. if (sum == n) {
  26. for (int i = 0; i < n; i++)
  27. System.out.println(g[i]);
  28. System.out.println();
  29. }
  30. return;
  31. }
  32. dfs(x, y + 1, sum);
  33. if (row[x] == 0 && col[y] == 0 && dg[y + x] == 0 && udg[y - x + n] == 0) {
  34. row[x] = col[y] = dg[y + x] = udg[y - x + n] = 1;
  35. g[x][y] = 'Q';
  36. dfs(x, y+1, sum + 1);
  37. g[x][y] = '.';
  38. row[x] = col[y] = dg[y + x] = udg[y - x + n] = 0;
  39. }
  40. }
  41. }

方法二

  1. import java.util.*;
  2. public class Main {
  3. static int n;
  4. static char[][] g;
  5. static int[] col, dg, udg;
  6. public static void main(String[] swe) {
  7. Scanner sc = new Scanner(System.in);
  8. n = sc.nextInt();
  9. g = new char[n][n];
  10. col = new int[n];
  11. dg = new int[2 * n];
  12. udg = new int[2 * n];
  13. for (int i = 0; i < n; i++) {
  14. for (int j = 0; j < n; j++) {
  15. g[i][j] = '.';
  16. }
  17. }
  18. dfs(0);
  19. }
  20. static void dfs(int u) {
  21. if (u == n) {
  22. for (int i = 0; i < n; i++) {
  23. System.out.println(g[i]);
  24. }
  25. System.out.println();
  26. return;
  27. }
  28. for (int i = 0; i < n; i++) {
  29. if (col[i] == 0 && dg[i + u] == 0 && udg[i - u + n] == 0) {
  30. g[u][i] = 'Q';
  31. col[i] = 1;
  32. dg[i + u] = 1;
  33. udg[i - u + n] = 1;
  34. dfs(u + 1);
  35. g[u][i] = '.';
  36. col[i] = 0;
  37. dg[i + u] = 0;
  38. udg[i - u + n] = 0;
  39. }
  40. }
  41. }
  42. }

n皇后.pdf