1

可能重复:
由数字组成的图案围绕一个矩形按顺时针方向移动(长度和宽度每次都减小)

如何使用 JAVA 以螺旋顺序打印二维数组?请帮忙,我没有任何想法。

样本数组:

1  2  3  4

5  6  7  8

9  10 11 12

13 14 15 16

输出:

1 2 3 4 8 12 16 15 14 13 9 5 6 7 11 10

这是我尝试过的:

公共静态无效主要(字符串[]参数){

    int[][] values = {{1,2,3,4}, {5,6,7,8}, {9,10,11,12}, {13,14,15,16}};

    for (int i = (values.length * values[0].length)-1, j = 0; i > 0; i--, j++) {
          for (int k = j; k < i; k++) {
              System.out.print(values[j][k]);
          }

          for (int k = j; k < i; k++) {
              System.out.print(values[k][i]);
          }

          for (int k = i; k > j; k--) {
              System.out.print(values[i][k]);
          }

          for (int k = i; k > j; k--) {
              System.out.print(values[k][j]);
          }
    }

}
4

2 回答 2

3
void PrintSpiral(int[][] arr, int size)
{
    for (int l = 0; l < size / 2; l++)
    {
        int min = l;
        int max = size - 1 - l;
        for (int i = min; i < max; i++)
            System.out.print("\t" + arr[i][min].ToString());
        for (int j = min; j < max; j++)
            System.out.print("\t" + arr[max][j].ToString());
        for (int i = max; i > min; i--)
            System.out.print("\t" + arr[i][max].ToString());
        for (int j = max; j > min; j--)
            System.out.print("\t" + arr[min][j].ToString());
    }
    // centre is special case: avoiding printing it 4 times.
    if (size % 2 == 1)
        System.out.print("\t" + arr[size / 2][size / 2].ToString());
}

(免责声明:仅在 C# 上尝试过)

于 2011-10-20T18:53:14.990 回答
1

这是一些Java解决方案:

public static final int X_SIZE = 4;
public static final int Y_SIZE = 4;

public static void main(String[] args) {
    int[][] array = new int[X_SIZE][Y_SIZE];

    for(int i = 0; i < X_SIZE; i++){
        for (int j = 0; j < Y_SIZE; j++){
            array[i][j] = i * X_SIZE + (j + 1);
            System.out.print(array[i][j] + " ");
        } 
        System.out.println();
    }

    System.out.println("************");
    System.out.println("Spiral");       

    spiralPrint(X_SIZE, Y_SIZE, array);
}

public static void spiralPrint(int xSize, int ySize, int matrix[][]){
    int i,  k = 0, l = 0;
    xSize--;  ySize--;      

    while(k <= xSize && l <= ySize){
        for(i = l; i <= ySize; ++i) {
            System.out.print(matrix[k][i]+ " ");
        }           
        k++;

        for(i = k; i <= xSize; ++i) {
            System.out.print(matrix[i][ySize] + " ");
        }
        ySize--;

        for(i = ySize; i >= l; --i) {
                System.out.print(matrix[xSize][i] + " ");
        }
        xSize--;


        for(i = xSize; i >= k; --i) {
            System.out.print(matrix[i][l] + " ");
        }
        l++;
    }
}
于 2011-10-20T19:07:14.400 回答