c++1. 编写求一个2*3阶矩阵与其自身转置矩阵的乘积的程序。 要求1:自定义一个函数求m*n阶矩阵的转置,自定义一个函数求两个矩阵的乘积。
时间: 2024-03-07 20:48:45 浏览: 136
C++矩阵库_C++调用矩阵_矩阵函数库_
5星 · 资源好评率100%
下面是C++代码实现:
```c++
#include <iostream>
using namespace std;
// 定义矩阵转置函数
void transpose(int matrix[][3], int row, int col, int result[][2])
{
for (int i = 0; i < row; i++)
{
for (int j = 0; j < col; j++)
{
result[j][i] = matrix[i][j];
}
}
}
// 定义矩阵乘法函数
void matrix_multiply(int matrix1[][3], int row1, int col1, int matrix2[][2], int row2, int col2, int result[][2])
{
for (int i = 0; i < row1; i++)
{
for (int j = 0; j < col2; j++)
{
int sum = 0;
for (int k = 0; k < col1; k++)
{
sum += matrix1[i][k] * matrix2[k][j];
}
result[i][j] = sum;
}
}
}
int main()
{
int matrix[2][3] = {{1, 2, 3}, {4, 5, 6}};
int transpose_matrix[3][2];
int result[2][2];
// 求矩阵转置
transpose(matrix, 2, 3, transpose_matrix);
// 求矩阵乘积
matrix_multiply(matrix, 2, 3, transpose_matrix, 3, 2, result);
// 输出结果
for (int i = 0; i < 2; i++)
{
for (int j = 0; j < 2; j++)
{
cout << result[i][j] << " ";
}
cout << endl;
}
return 0;
}
```
运行结果:
```
14 32
32 77
```
阅读全文