1 package test; 2 /* 3 * 1 2 3 4 5 4 * 16 17 18 19 6 5 * 15 24 25 20 7 6 * 14 23 22 21 8 7 * 13 12 11 10 9 8 * 9 * 寫一方法,打印等長的二維數組,要求從1開始的天然數由方陣的最外圈向內螺旋方式地順序排列。 10 * */ 11 public class Test6 12 { 13 public static void main(String[] args) 14 { 15 arraynum(4); 16 } 17 // 便於改代碼..輸入不一樣y值輸出不一樣的二維數列 18 private static void arraynum(int x) 19 { 20 int[][] arr = new int[x][x]; 21 int len = arr.length, max = 0, count = 0; 22 specArr(arr, len, max, count); 23 arrprint(arr); 24 } 25 // 高級for輸出打印用的 26 private static void arrprint(int[][] arr) 27 { 28 for (int[] in : arr) 29 { 30 for (int t : in) 31 { 32 System.out.print(t + "\t"); 33 } 34 System.out.println(); 35 } 36 } 37 private static void specArr(int[][] arr, int len, int max, int count) 38 { 39 while (len > 0) 40 { 41 int j = 0; 42 for (int index = 0; index < (len - 1) * 4; index++) 43 { 44 if (index < len - 1) 45 arr[0 + count][index + count] = ++max; 46 else if (index < 2 * (len - 1)) 47 arr[count + j++][arr.length - 1 - count] = ++max; 48 else if (index < 3 * (len - 1)) 49 arr[arr.length - 1 - count][(j--) + count] = ++max; 50 else if (index < 4 * (len - 1)) 51 arr[arr.length - 1 - (j++) - count][0 + count] = ++max; 52 } 53 if (len == 1) 54 { 55 arr[arr.length / 2][arr.length / 2] = max + 1; 56 }// 注意到 當y值爲奇數時,會有循環到n=1的狀況,須要補進數組最中間值 57 count++; 58 len = len - 2; 59 } 60 } 61 }