任意输入两个4乘4的矩阵A和B,计算并输出A和B的乘积矩阵
时间: 2024-05-05 18:19:41 浏览: 154
好的,可以使用以下代码来实现矩阵的乘法运算:
```python
# 定义两个4x4的矩阵A和B
A = [[1, 2, 3, 4],
[5, 6, 7, 8],
[9, 10, 11, 12],
[13, 14, 15, 16]]
B = [[1, 0, 0, 0],
[0, 1, 0, 0],
[0, 0, 1, 0],
[0, 0, 0, 1]]
# 定义结果矩阵C
C = [[0 for j in range(4)] for i in range(4)]
# 计算矩阵A和B的乘积
for i in range(4):
for j in range(4):
for k in range(4):
C[i][j] += A[i][k] * B[k][j]
# 输出结果矩阵C
for i in range(4):
for j in range(4):
print(C[i][j], end=' ')
print()
```
这里我们定义了两个4x4的矩阵A和B,并通过三重循环计算它们的乘积矩阵C。最后输出结果矩阵C即可。
相关问题
任意输入两个矩阵,计算并输出两个矩阵的乘积矩阵用c程序怎么写
可以使用双重循环实现矩阵的乘积,具体代码如下:
```c
#include <stdio.h>
int main() {
int row1, col1, row2, col2;
printf("Enter the dimensions of the first matrix: ");
scanf("%d %d", &row1, &col1);
printf("Enter the dimensions of the second matrix: ");
scanf("%d %d", &row2, &col2);
// Check if matrices can be multiplied
if (col1 != row2) {
printf("Matrices cannot be multiplied!\n");
return 0;
}
int mat1[row1][col1], mat2[row2][col2], prod[row1][col2];
// Input matrices
printf("Enter the elements of the first matrix:\n");
for (int i = 0; i < row1; i++) {
for (int j = 0; j < col1; j++) {
scanf("%d", &mat1[i][j]);
}
}
printf("Enter the elements of the second matrix:\n");
for (int i = 0; i < row2; i++) {
for (int j = 0; j < col2; j++) {
scanf("%d", &mat2[i][j]);
}
}
// Multiply matrices
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 += mat1[i][k] * mat2[k][j];
}
prod[i][j] = sum;
}
}
// Print product matrix
printf("Product matrix:\n");
for (int i = 0; i < row1; i++) {
for (int j = 0; j < col2; j++) {
printf("%d ", prod[i][j]);
}
printf("\n");
}
return 0;
}
```
在这个程序中,首先从用户输入中获取两个矩阵的维度,然后检查它们是否可以相乘。如果可以,就分别输入两个矩阵的元素,并使用三重循环计算它们的乘积。最后,输出结果矩阵。
用C++实现这样一个程序:输入任意大小的两个矩阵。计算两个矩阵的乘积并输出在终端
好的,下面是用 C 语言实现的程序,它可以输入两个任意大小的矩阵,并计算它们的乘积并在终端输出。
首先,需要包含 stdio.h 和 stdlib.h 头文件。
然后,定义一个函数用于读入矩阵的大小和元素,并返回一个指向矩阵的指针。
```
double** readMatrix(int* rows, int* cols) {
// 读入矩阵的行数和列数
scanf("%d %d", rows, cols);
// 分配内存空间存储矩阵
double** matrix = (double**)malloc(*rows * sizeof(double*));
for (int i = 0; i < *rows; i++) {
matrix[i] = (double*)malloc(*cols * sizeof(double));
}
// 读入矩阵的元素
for (int i = 0; i < *rows; i++) {
for (int j = 0; j < *cols; j++) {
scanf("%lf", &matrix[i][j]);
}
}
return matrix;
}
```
然后,定义一个函数用于计算两个矩阵的乘积并返回结果矩阵。
```
double** matrixMultiply(double** A, int A_rows, int A_cols, double** B, int B_rows, int B_cols) {
// 分配内存空间存储结果矩阵
double** C = (double**)malloc(A_rows * sizeof(double*));
for (int i = 0; i < A_rows; i++) {
C[i] = (double*)malloc(B_cols * sizeof(double));
}
// 计算矩阵乘积
for (int i = 0; i < A_rows; i++) {
for (int j = 0; j < B_cols; j++) {
C[i][j] = 0;
for (int k = 0; k < A_cols; k++) {
C[i][j] += A[i][k] * B[k][j];
阅读全文