日期:2014-05-20 浏览次数:20993 次
public class tour { final static public int M = 8;// static public int[][] path = new int[M][M];// 记录步子的数组 final static int[] dx = new int[] { 2, 1, -1, -2, -2, -1, 1, 2 }; final static int[] dy = new int[] { -1, -2, -2, -1, 1, 2, 2, 1 };// pose public static int counter = 0; public static int total = 0; public tour() { } public static void initpath() { for (int i = 0; i < M; i++) for (int j = 0; j < M; j++) path[i][j] = 0;// 将数组初始为0 } static public void display() { for (int i = 0; i < M; i++) for (int j = 0; j < M; j++) { initpath(); counter = 0; set(i, j); // initpath(); } } public static void set(int x, int y) { if (test(x, y)) { path[x][y] = counter++; /* System.out.println(counter); */ if (counter == M * M + 1) { total++; System.out.printf("第%d种\n", total); for (int s = 0; s < M; s++) { for (int t = 0; t < M; t++) System.out.printf("%2d ", path[s][t]); System.out.println(); } }// 打印 //System.out.println(); for (int i = 0; i < 8; i++) { set(x + dx[i], y + dy[i]); } } } private static boolean test(int x, int y) { if (x < 0 || x >= M || y < 0 || y >= M) return false; else if (path[x][y] == 0) return true; return false; } public static void main(String args[]) { display(); } }