单片机/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)。


相关推荐
郝YH是人间理想10 小时前
考研数学二图鉴——矩阵
线性代数·考研·矩阵
所愿ღ10 小时前
SSM框架-Spring1
java·开发语言·笔记·spring
威迪斯特10 小时前
Gorilla框架:Go语言生态中的模块化开发利器
运维·开发语言·后端·golang·web框架·维护·gorilla
格林威10 小时前
面阵相机 vs 线阵相机:堡盟与海康相机选型差异全解析 附C# 实战演示
开发语言·人工智能·数码相机·计算机视觉·c#·视觉检测·工业相机
A_aspectJ10 小时前
【Java基础开发】基于 Java Swing 开发的简易计算器 - 支持键盘
java·开发语言
光影少年10 小时前
vite+rust生态链工具链
开发语言·前端·后端·rust·前端框架
skywalk816310 小时前
当前有什么流行的lisp的web框架吗?
开发语言·前端·lisp
️是7810 小时前
信息奥赛一本通—编程启蒙(3380:练65.3 螺旋矩阵)
线性代数·算法·矩阵
天若有情67310 小时前
C++进阶:普通重载运算符 vs 隐式类型转换重载运算符,一篇讲透区别
开发语言·c++·算法
流年如夢10 小时前
文件读写操作与易错点总结
c语言