首页 > 后端开发 > C++ > 正文

c++ 矩阵乘法代码 c++矩阵运算实现教程

下次还敢
发布: 2025-11-29 15:38:02
原创
739人浏览过
矩阵乘法需满足A的列数等于B的行数,结果为m×p矩阵,核心计算为Ci=Σ(Ai×Bk);C++实现通过Matrix类封装二维vector,重载*运算符执行三重循环计算,并检查维度匹配;使用示例展示2×3与3×2矩阵相乘得2×2结果;可优化方向包括一维数组存储、模板化、运算符重载扩展及OpenMP/SIMD加速。

c++ 矩阵乘法代码 c++矩阵运算实现教程

矩阵乘法是线性代数中的基本运算之一,在科学计算、图像处理和机器学习中广泛应用。C++ 提供了良好的性能支持,适合实现高效的矩阵运算。下面是一个简洁、清晰的 C++ 矩阵乘法实现,并附带基础矩阵类的设计思路。

1. 矩阵乘法的基本原理

两个矩阵 A 和 B 能相乘的前提是:A 的列数等于 B 的行数。若 A 是 m×n 矩阵,B 是 n×p 矩阵,则结果 C 是 m×p 矩阵,其中:

C[i][j] = Σ (A[i][k] × B[k][j]),k 从 0 到 n-1

2. 基础矩阵类设计

我们用一个简单的 Matrix 类封装二维数据,支持构造、乘法操作。

立即学习C++免费学习笔记(深入)”;

#include <iostream>
#include <vector>
<p>class Matrix {
public:
int rows, cols;
std::vector<std::vector<double>> data;</p><pre class='brush:php;toolbar:false;'>// 构造函数
Matrix(int r, int c) : rows(r), cols(c), data(r, std::vector<double>(c, 0)) {}

// 矩阵乘法
Matrix operator*(const Matrix& other) const {
    if (cols != other.rows) {
        std::cerr << "矩阵维度不匹配:无法相乘!\n";
        return Matrix(0, 0); // 返回空矩阵表示错误
    }

    Matrix result(rows, other.cols);
    for (int i = 0; i < rows; ++i) {
        for (int j = 0; j < other.cols; ++j) {
            double sum = 0;
            for (int k = 0; k < cols; ++k) {
                sum += data[i][k] * other.data[k][j];
            }
            result.data[i][j] = sum;
        }
    }
    return result;
}

// 打印矩阵
void print() const {
    for (int i = 0; i < rows; ++i) {
        for (int j = 0; j < cols; ++j) {
            std::cout << data[i][j] << "\t";
        }
        std::cout << "\n";
    }
}
登录后复制

};

3. 使用示例

下面演示如何创建矩阵并执行乘法运算。

matlab基础知识简介 中文WORD版
matlab基础知识简介 中文WORD版

MATLAB(矩阵实验室)是MATrix LABoratory的缩写,是一款由美国The MathWorks公司出品的商业数学软件。MATLAB是一种用于算法开发、数据可视化、数据分析以及数值计算的高级技术计算语言和交互式环境。除了矩阵运算、绘制函数/数据图像等常用功能外,MATLAB还可以用来创建用户界面及与调用其它语言(包括C,C++和FORTRAN)编写的程序。MATLAB基础知识;命令窗口是用户与MATLAB进行交互作业的主要场所,用户输入的MATLAB交互命令均在命令窗口执行。 感兴趣的朋友可以

matlab基础知识简介 中文WORD版 0
查看详情 matlab基础知识简介 中文WORD版
int main() {
    Matrix A(2, 3);
    A.data = {{1, 2, 3},
              {4, 5, 6}};
<pre class='brush:php;toolbar:false;'>Matrix B(3, 2);
B.data = {{7,  8},
          {9,  10},
          {11, 12}};

Matrix C = A * B;

std::cout << "结果矩阵 C = A × B:\n";
C.print();

return 0;
登录后复制

}

输出结果为:

46 52
139 154

4. 优化与扩展建议

上述实现适用于教学和小型计算。实际应用中可考虑以下改进:

  • 使用一维数组存储数据(提升缓存效率)
  • 重载更多运算符(+、-、=)
  • 添加异常处理机制
  • 支持模板类型(int、float、complex)
  • 引入 OpenMP 或 SIMD 加速内层循环

基本上就这些。这个实现足够清晰,便于理解矩阵乘法的核心逻辑,也能作为更复杂矩阵库的基础。不复杂但容易忽略的是维度检查和内存布局优化。

以上就是c++++ 矩阵乘法代码 c++矩阵运算实现教程的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号