先上题目
给定一个矩阵 A
, 返回 A
的转置矩阵。
矩阵的转置是指将矩阵的主对角线翻转,交换矩阵的行索引与列索引。
示例 1:
输入:[[1,2,3],[4,5,6],[7,8,9]] 输出:[[1,4,7],[2,5,8],[3,6,9]]
示例 2:
输入:[[1,2,3],[4,5,6]] 输出:[[1,4],[2,5],[3,6]]
提示:
1 <= A.length <= 1000
1 <= A[0].length <= 1000
思路
1.获取原矩阵行列长度,循环原矩阵
2.循环过程,按照倒置行列存储元素到新数组
代码部分(耗时5ms)
class Solution {
public int[][] transpose(int[][] A) {
int lineLen,columnLen,n =0,m =0;
int[][] newNums;
lineLen=A.length;
columnLen =A[0].length;
newNums =new int [columnLen][lineLen];
for(int i =0;i<lineLen;i++){
for(int j =0;j<columnLen;j++){
if(n >=columnLen){
n =0;
m++;
}
newNums[n][m] =A[i][j];
n++;
}
}
return newNums;
}
}