1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
| package algorithm;
import java.util.*;
public class NQueens {
public static List<List<String>> solveNQueens(int n) { List<List<String>> ans = new ArrayList<>(); int[] queens = new int[n]; Arrays.fill(queens, -1); Set<Integer> columns = new HashSet<>(); Set<Integer> diagonals1 = new HashSet<>(); Set<Integer> diagonals2 = new HashSet<>();
// 从第0行开始 track(ans, queens, n, 0, columns, diagonals1, diagonals2);
return ans; }
private static void track(List<List<String>> ans, int[] queens, int n, int row, Set<Integer> columns, Set<Integer> diagonals1, Set<Integer> diagonals2) {
if (row == n) { List<String> strings = generateBoard(n, queens); ans.add(strings); } else { // 每一行都要从第0列开始遍历 for (int i = 0; i < n; i++) { if (columns.contains(i)) { continue; } int diagonal1 = row - i; if (diagonals1.contains(diagonal1)) { continue; } int diagonal2 = row + i; if (diagonals2.contains(diagonal2)) { continue; } queens[row] = i; columns.add(i); diagonals1.add(diagonal1); diagonals2.add(diagonal2); track(ans, queens, n, row + 1, columns, diagonals1, diagonals2); queens[row] = -1; columns.remove(i); diagonals1.remove(diagonal1); diagonals2.remove(diagonal2); } } }
private static List<String> generateBoard(int n, int[] queens) { List<String> result = new ArrayList<>();
for (int i = 0; i < n; i++) { char[] row = new char[n]; Arrays.fill(row, '.'); row[queens[i]] = 'Q'; String s = new String(row); result.add(s); } return result; }
public static void main(String[] args) { System.out.println(solveNQueens(4));
System.out.println(solveNQueens(1)); } }
|