习题:已知一个二维数组A 表示一个矩阵,求AT。 其中,AT 表示矩阵的转置。 矩阵转置的含义:表示把一个矩阵行列互换。例如, 有下面的矩阵M 以及其转置MT:
思路:参照图例发现共通点:A的行数与B的列数相同。(A为2行3列,B为3行2列)
所以要定义一个双层循环,外层循环的循环条件为B数组的行数,内层循环条件为B数组的列数,
外层第一次循环时要在内层循环中将:
A[0][0]==B[0][0]
A[1][0]==B[0][1],
第二次循环时:
A[0][1]==B[1][0],
A[1][1]==B[1][1]
第三次循环:
A[0][2]==B[2][0]
A[1][2]==B[2][1];
public static void chap_6()
{
//为了提高阅读性,二维数组的定义稍微有些麻烦。
int[][] arr = new int[2][3];
arr[0][0] = 1;
arr[0][1] = 2;
arr[0][2] = 3;
arr[1][0] = 4;
arr[1][1] = 5;
arr[1][2] = 6;
int[][] arrT = new int[3][2];
for(int i=0; i<arrT.length; i++)
{
int[] arr2 = arrT[i];
for(int j=0; j<arr2.length; j++)
{
int q = arr[j][i];
arrT[i][j] = q;
}
}
System.out.println("复制完成");
for(int i=0; i<arrT.length; i++)
{
int[] arr2 = arrT[i];
for(int j=0; j<2; j++)
{
System.out.print(arrT[i][j]);
}
System.out.println();
}
}