编写函数实现m*n的整数矩阵转置
时间: 2023-05-21 15:07:03 浏览: 176
以下是一个实现m*n的整数矩阵转置的函数示例:
```python
def matrix_transpose(matrix):
# 获取矩阵的行数和列数
rows, cols = len(matrix), len(matrix[0])
# 生成一个新矩阵,用于存放转置后的矩阵
transposed = [[0] * rows for _ in range(cols)]
# 遍历原矩阵,将每一个元素转置到新矩阵中对应的位置上
for i in range(rows):
for j in range(cols):
transposed[j][i] = matrix[i][j]
return transposed
```
这个函数可以接受一个m*n的整数矩阵作为参数,返回其转置后的n*m的新矩阵。
例如,如果原矩阵为[[1, 2, 3], [4, 5, 6]],则转置后的矩阵为[[1, 4], [2, 5], [3, 6]]。
希望这个函数可以帮助您解决问题!
相关问题
C语言编写函数实现m*n的整数矩阵转置
以下是函数实现m*n的整数矩阵转置的 C 代码:
```c
void transpose(int array[m][n])
{
int i, j, temp;
for(i=0; i<m; i++)
{
for(j=i+1; j<n; j++)
{
temp = array[i][j];
array[i][j] = array[j][i];
array[j][i] = temp;
}
}
}
```
该函数接受一个大小为 m*n 的矩阵,将其转置后保存在原来的数组中。在主函数中,只需要调用该函数并将矩阵作为参数传递即可。
编写并测试3*3矩阵转置函数,使用数组保存3*3矩阵C++
以下是一个简单的C++程序,实现了3x3矩阵的转置功能:
```c++
#include<iostream>
using namespace std;
void transpose(int A[][3], int B[][3]) {
for(int i=0; i<3; i++) {
for(int j=0; j<3; j++) {
B[i][j] = A[j][i];
}
}
}
int main() {
int A[3][3] = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};
int B[3][3];
transpose(A, B);
cout << "Original matrix:" << endl;
for(int i=0; i<3; i++) {
for(int j=0; j<3; j++) {
cout << A[i][j] << " ";
}
cout << endl;
}
cout << "Transposed matrix:" << endl;
for(int i=0; i<3; i++) {
for(int j=0; j<3; j++) {
cout << B[i][j] << " ";
}
cout << endl;
}
return 0;
}
```
输出结果为:
```
Original matrix:
1 2 3
4 5 6
7 8 9
Transposed matrix:
1 4 7
2 5 8
3 6 9
```
在这个程序中,我们定义了一个 `transpose` 函数,该函数接受两个3x3的整数数组 `A` 和 `B` 作为参数。在这个函数中,我们使用两个嵌套的循环来遍历矩阵 `A`,并将转置后的结果存储在矩阵 `B` 中。最后,我们在主函数中调用了 `transpose` 函数,并分别打印了原始矩阵和转置后的矩阵。