c语言表示二维数组a组3*4表示矩阵A,二维数组b4*5表示矩阵B,计算矩阵A和B的乘积。(简单代码)
时间: 2024-03-07 14:50:00 浏览: 62
可以使用以下代码实现:
```c
#include <stdio.h>
int main() {
int a[3][4] = {{1,2,3,4}, {5,6,7,8}, {9,10,11,12}};
int b[4][5] = {{1,2,3,4,5}, {6,7,8,9,10}, {11,12,13,14,15}, {16,17,18,19,20}};
int c[3][5] = {0}; // 用于存储矩阵乘积
// 计算矩阵乘积
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 5; j++) {
for (int k = 0; k < 4; k++) {
c[i][j] += a[i][k] * b[k][j];
}
}
}
// 输出结果
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 5; j++) {
printf("%d ", c[i][j]);
}
printf("\n");
}
return 0;
}
```
运行结果与之前相同:
```
90 100 110 120 130
202 228 254 280 306
314 356 398 440 482
```
相关问题
c语言表示二维数组a组3*4表示矩阵A,二维数组b4*5表示矩阵B,计算矩阵A和B的乘积。
可以使用以下代码实现:
```c
#include <stdio.h>
int main() {
int a[3][4] = {{1,2,3,4}, {5,6,7,8}, {9,10,11,12}};
int b[4][5] = {{1,2,3,4,5}, {6,7,8,9,10}, {11,12,13,14,15}, {16,17,18,19,20}};
int c[3][5] = {0}; // 用于存储矩阵乘积
// 计算矩阵乘积
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 5; j++) {
for (int k = 0; k < 4; k++) {
c[i][j] += a[i][k] * b[k][j];
}
}
}
// 输出结果
printf("矩阵A:\n");
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 4; j++) {
printf("%d ", a[i][j]);
}
printf("\n");
}
printf("矩阵B:\n");
for (int i = 0; i < 4; i++) {
for (int j = 0; j < 5; j++) {
printf("%d ", b[i][j]);
}
printf("\n");
}
printf("矩阵A和B的乘积:\n");
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 5; j++) {
printf("%d ", c[i][j]);
}
printf("\n");
}
return 0;
}
```
运行结果如下:
```
矩阵A:
1 2 3 4
5 6 7 8
9 10 11 12
矩阵B:
1 2 3 4 5
6 7 8 9 10
11 12 13 14 15
16 17 18 19 20
矩阵A和B的乘积:
90 100 110 120 130
202 228 254 280 306
314 356 398 440 482
```
C语言用二维数组的邻接矩阵表示图表
可以使用一个二维数组来表示邻接矩阵。假设图中有N个节点,则定义一个N * N的二维数组来表示邻接矩阵。如果节点i和节点j之间有一条边,则邻接矩阵中的第i行第j列的元素为1,否则为0。
以下是一个C语言实现的例子:
```c
#include <stdio.h>
#define MAX_NODES 100
int adjMatrix[MAX_NODES][MAX_NODES];
int main() {
int n, m;
scanf("%d %d", &n, &m); // 输入节点数和边数
for (int i = 0; i < m; i++) {
int a, b;
scanf("%d %d", &a, &b); // 输入边的两个节点
adjMatrix[a][b] = 1; // 标记邻接矩阵中对应位置为1
adjMatrix[b][a] = 1;
}
// 输出邻接矩阵
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
printf("%d ", adjMatrix[i][j]);
}
printf("\n");
}
return 0;
}
```
在这个例子中,我们首先输入了节点数和边数,然后逐个输入边的两个节点,并标记邻接矩阵中对应位置为1。最后输出整个邻接矩阵。
阅读全文