|
第一种办法
1 import java.text.DecimalFormat;
2data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
3data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt="" public class HelixMatrix {
4 private int[][] array;
5 private int m,n;
6data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" public HelixMatrix(int m, int n) {
7 this.m = m;
8 this.n = n;
9 array = new int[m][];
10 for(int i = 0; i < m; i++)
11 array[i] = new int[n];
12 }
13data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
14data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" private void fill() {
15 int count = m * n;
16 int direct = 0;
17 int round = 1;
18data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" for(int index = 1, x = 0, y = 0; index <= count; index++) {
19 array[x][y] = index;
20data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" switch(direct) {
21 case 0: //向右
22 if(y < n - round)
23 y++;
24data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" else {
25 direct = 1;
26 x++;
27 }
28 break;
29 case 1:
30 if(x < m - round)
31 x++;
32data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" else {
33 direct = 2;
34 y--;
35 }
36 break;
37 case 2:
38 if(y >= round)
39 y--;
40data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" else {
41 direct = 3;
42 x--;
43 }
44 break;
45 case 3:
46 if(x > round)
47 x--;
48data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" else {
49 direct = 0;
50 round++;
51 y++;
52 }
53 break;
54 }
55 }
56 }
57data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
58data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" private void printMatrix() {
59 DecimalFormat df = new DecimalFormat(" 000");
60data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" for(int i = 0; i < m; i++) {
61 for(int j = 0; j < n; j++)
62 System.out.print(df.format(array[i][j]));
63 System.out.println();
64 }
65 }
66
67data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" public static void main(String[] args) {
68 HelixMatrix matrix = new HelixMatrix(8,6);
69 matrix.fill();
70 matrix.printMatrix();
71 }
72 }
第二种办法
1data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt="" public class ScrewSquare {
2data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
3data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" public static void main(String[] args) {
4 int w = 5;
5 int h = 5;
6 int[][] array = new int[w][h];
7 fill(array, 0, 0, w-1, h-1, 1);
8data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" for (int y=0; y<h; y++) {
9data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" for (int x=0; x<w; x++) {
10 System.out.printf("%2d ", array[x][y]);
11 }
12 System.out.println();
13 }
14 }
15data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
16data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" public static void fill(int[][] array, int left, int top, int right, int bottom, int start) {
17 if (left > right || top > bottom) return;
18data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
19 for (int x=left; x<=right; x++)
20 array[x][top] = start++;
21data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
22 for (int y=top+1; y<=bottom; y++)
23 array[right][y] = start++;
24data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
25 for (int x=right-1; x>=left; x--)
26 array[x][bottom] = start++;
27data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
28 for (int y=bottom-1; y>=top+1; y--)
29 array[left][y] = start++;
30data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
31 fill(array, left+1, top+1, right-1, bottom-1, start);
32 }
33 }
|