Java,将2D矩阵对角线与中线交换

时间:2018-12-05 08:28:04

标签: java arrays multidimensional-array swap

我想问一些愚蠢的问题,这些问题实际上困扰了我一段时间,而我却找不到任何解决方案。

例如,我有一个Java 2D数组

String arraylist numberSeq[][];

在数组列表中,有1到25之间的数字,

numberSeq[0][0] = 1, [0][1] = 2, [0][2] = 3 , [0][3] = 4 , [0][4] = 5
numberSeq[1][0] = 6, [1][1] = 7, [1][2] = 8 , [1][3] = 9 , [1][4] = 10
......
numberSeq[4][0] = 21,[4][1] = 22,[4][2] = 23, [4][3] = 24, [4][4] = 25

所以数字会像

1  2  3  4  5
6  7  8  9  10
11 12 13 14 15
16 17 18 19 20
21 22 23 24 25

对角交换后,希望输出像

25 20 15 10 5
24 19 14 9  4
23 18 13 8  3
22 17 12 7  2
21 16 11 6  1

我可以知道如何仅声明1个局部变量吗?

如果无法实现1个局部变量try,那么我可以实现的最小声明局部变量是多少?

非常感谢。

3 个答案:

答案 0 :(得分:2)

这应该有所帮助。是的,可以只交换一个局部变量。

ip r

从本质上讲,我每第N列都要遍历“总行-N”,因此,可以帮助我遍历以下结构:

public swapDiagonally(int[][] mtx) {
  for(int i = 0 ;i< mtx.length; i++){
     for(int j = 0; j < mtx[0].length - i; j++){ 
        int temp = mtx[i][j];
        mtx[j][i]; = mtx[mtx.length-1-i][mtx[0].length-1-j];
        mtx[mtx.length-1-i][mtx[0].length-1-j] = temp;
     }
  } 
}

用于4x4阵列!

答案 1 :(得分:0)

以下循环将按照您的问题进行对角线交换:

    int n=5;
    int[][] newmat = new int[5][5];
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++) {
            newmat[(n-1) - j][(n-1)- i] = matrix[i][j];
        }
    }

答案 2 :(得分:-1)

您可以通过制作另一个teo维度数组,以正确的顺序遍历第一个并将其发布到新的数组来实现此目的。

public class MyClass {
    public static void main(String args[]) {

        int dimension = 5;

        int[][] numberSeq = new int[dimension][dimension];

        numberSeq[0][0] = 1; numberSeq[0][1] = 2;numberSeq[0][2] = 3;numberSeq[0][3] = 4;numberSeq[0][4] = 5;
        numberSeq[1][0] = 6; numberSeq[1][1] = 7;numberSeq[1][2] = 8;numberSeq[1][3] = 9;numberSeq[1][4] = 10;
        numberSeq[2][0] = 11;numberSeq[2][1] = 12;numberSeq[2][2] = 13;numberSeq[2][3] = 14;numberSeq[2][4] = 15;
        numberSeq[3][0] = 16;numberSeq[3][1] = 17;numberSeq[3][2] = 18;numberSeq[3][3] = 19;numberSeq[3][4] = 20;
        numberSeq[4][0] = 21;numberSeq[4][1] = 22;numberSeq[4][2] = 23;numberSeq[4][3] = 24;numberSeq[4][4] = 25;

        int[][] flippedSeq = new int[dimension][dimension];

        // This is the flipping part
        for(int i = 0; i < dimension; i++)
        {
            for(int j = 0; j < dimension; j++)
            {
                flippedSeq[i][j] = numberSeq[dimension-1-j][dimension-1-i];
            }
        }

        PrintMatrix(numberSeq);
        System.out.println();
        PrintMatrix(flippedSeq);


    }

    public static void PrintMatrix(int[][] mat)
    {
        for(int i = 0; i < mat.length; i++)
        {
            for(int j = 0; j < mat[i].length; j++)
                System.out.print(mat[i][j] + " ");
            System.out.println();
        }
    }
}

我希望这就是您所说的“ 1个局部变量”。

输出为:

1 2 3 4 5 
6 7 8 9 10 
11 12 13 14 15 
16 17 18 19 20 
21 22 23 24 25 

25 20 15 10 5 
24 19 14 9 4 
23 18 13 8 3 
22 17 12 7 2 
21 16 11 6 1