单片机/C语言八股:(十三)C 语言实现矩阵乘法

上一篇 下一篇
C 语言中 malloc 和 free 用法(动态分配内存)

目 录


矩阵乘法

1)数学公式

设有两个矩阵:

  • 矩阵 A 是一个 m × n m×n m×n 的矩阵(m 行 n 列)
  • 矩阵 B 是一个 n × p n×p n×p 的矩阵(n 行 p 列)

只有当 A 的列数等于 B 的行数时,才能相乘。

它们的乘积 C = A × B 是一个 m × p m×p m×p 的矩阵,其中每个元素 c i j c_{ij} cij 定义为:
c i j = ∑ k = 1 n a i k ⋅ b k j \large c_{ij}=\sum_{k=1}^{n}{a_{ik}⋅b_{kj}} cij=k=1∑naik⋅bkj

2)代码实现

2.1)静态数组

在程序中就指定矩阵的大小和矩阵的元素。

c 复制代码
#include <stdio.h>

int main() {
    // 定义两个固定的小矩阵 A (2x3) 和 B (3x2)
    int A[2][3] = {
        {1, 2, 3},
        {4, 5, 6}
    };

    int B[3][2] = {
        {7, 8},
        {9, 10},
        {11, 12}
    };

    // 结果矩阵 C (2x2),初始化为0
    int C[2][2] = {0};

    // 矩阵乘法:C = A * B
    for (int i = 0; i < 2; i++) {
        for (int j = 0; j < 2; j++) {
            for (int k = 0; k < 3; k++) {
                C[i][j] += A[i][k] * B[k][j];
            }
        }
    }

    // 打印结果
    printf("Result:\n");
    for (int i = 0; i < 2; i++) {
        for (int j = 0; j < 2; j++) {
            printf("%d ", C[i][j]);
        }
        printf("\n");
    }

    return 0;
}

运行结果如下:

c 复制代码
Result:
58 64
139 154

2.2)动态数组(动态分配内存)

在 C 语言中实现矩阵乘法,需要满足两个矩阵的维度兼容:若矩阵 A 是 m × n m×n m×n 的,矩阵 B 是 n × p n×p n×p 的,则它们的乘积 C 是一个 m × p m×p m×p 的矩阵。

c 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main() {
    // 定义矩阵 A (2x3) 和 B (3x4)
    int m = 2, n = 3, p = 4;
    int (*parray1)[n] = (int*)malloc(sizeof(int)*m*n);
    int (*parray2)[p] = (int*)malloc(sizeof(int)*n*p);
    int (*presult)[p] = (int*)malloc(sizeof(int)*m*p);

    /* 矩阵元素赋值 */
    for (int i = 0; i < m; i++) {
        for (int j = 0; j < n; j++) {
            parray1[i][j] = i*j+1;
        }
    }
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < p; j++) {
            parray2[i][j] = i+j;
        }
    }

    /* 矩阵乘法运算 */
    memset(presult, 0, m * p * sizeof(int));
    for (int i = 0; i < m; i++) {
        for (int j = 0; j < p; j++) {
            for (int k = 0; k < n; k++) {
                presult[i][j] += parray1[i][k] * parray2[k][j];
            }
        }
    }

    /* 打印矩阵乘法结果 */
    printf("result:\n");
    for (int i = 0; i < m; i++) {
        for (int j = 0; j < p; j++) {
            printf("%d ",presult[i][j]);
        }
        printf("\n");
    }

    free(parray1);
    free(parray2);
    free(presult);
    return 0;
}

运行结果为:

c 复制代码
result:
3 6 9 12
8 14 20 26

矩阵乘法的时间复杂度为 O ( m ⋅ n ⋅ p ) O(m⋅n⋅p) O(m⋅n⋅p) ,对于方阵( n × n n×n n×n )是 O ( n 3 ) O(n3) O(n3)。


相关推荐
晓晓hh1 小时前
JavaSE学习——迭代器
java·开发语言·学习
iFlyCai1 小时前
C语言中的指针
c语言·数据结构·算法
Laurence1 小时前
C++ 引入第三方库(一):直接引入源文件
开发语言·c++·第三方库·添加·添加库·添加包·源文件
kyriewen111 小时前
你点的“刷新”是假刷新?前端路由的瞒天过海术
开发语言·前端·javascript·ecmascript·html5
014-code1 小时前
String.intern() 到底干了什么
java·开发语言·面试
421!2 小时前
GPIO工作原理以及核心
开发语言·单片机·嵌入式硬件·学习
摇滚侠2 小时前
JAVA 项目教程《苍穹外卖-12》,微信小程序项目,前后端分离,从开发到部署
java·开发语言·vue.js·node.js
@insist1232 小时前
网络工程师-生成树协议(STP/RSTP/MSTP)核心原理与应用
服务器·开发语言·网络工程师·软考·软件水平考试
野生技术架构师3 小时前
2026年牛客网最新Java面试题总结
java·开发语言
环黄金线HHJX.3 小时前
Tuan符号系统重塑智能开发
开发语言·人工智能·算法·编辑器