一维数组,N皇后
?
import java.util.Arrays;public class test {public static void main(String[] args) {new test();}int count = 0;public test() {int N = 6;int[] a = new int[N];a[0] = -1;for (int i = 0; i < N; i++) {Arrays.fill(a, 1, N, -1);find(0, a, N);}System.out.println(count);}public void find(int row, int[] a, int length) {a[row]++;for (int i = 0; i <= row - 1; i++) {if (a[i] == a[row]) {return;}if (Math.abs(i - row) == Math.abs(a[i] - a[row])) {return;}}if (row + 1 < length) {for (int i = 0; i < length; i++) {Arrays.fill(a, row + 2, length, -1);find(row + 1, a, length);}} else {for (int i = 0; i < length; i++) {System.out.print(a[i] + "\t");}System.out.println();count++;}}}N皇后的解的个数,可以参考:
http://bbs.ednchina.com/BLOG_ARTICLE_2129140.HTM