输入两个稀疏矩阵,求相加,减,乘,及任一矩阵的转置结果,C++

时间: 2023-07-11 18:32:22 浏览: 39
以下是 C++ 的代码实现: ```c++ #include <iostream> #include <vector> using namespace std; // 定义稀疏矩阵结构体 struct SparseMatrix { int m, n; // 矩阵的行数和列数 vector<vector<int>> data; // 存储非零元素的值及其位置 }; // 矩阵加法 SparseMatrix add(SparseMatrix a, SparseMatrix b) { SparseMatrix c; if (a.m != b.m || a.n != b.n) { // 当两个矩阵的行列数不相同时,无法进行加法运算 cout << "Error: The two matrices can't be added." << endl; return c; } c.m = a.m; c.n = a.n; int i = 0, j = 0; while (i < a.data.size() && j < b.data.size()) { // 合并两个矩阵的非零元素 if (a.data[i][0] < b.data[j][0] || (a.data[i][0] == b.data[j][0] && a.data[i][1] < b.data[j][1])) { c.data.push_back(a.data[i]); i++; } else if (a.data[i][0] > b.data[j][0] || (a.data[i][0] == b.data[j][0] && a.data[i][1] > b.data[j][1])) { c.data.push_back(b.data[j]); j++; } else { if (a.data[i][2] + b.data[j][2] != 0) { c.data.push_back({a.data[i][0], a.data[i][1], a.data[i][2] + b.data[j][2]}); } i++; j++; } } while (i < a.data.size()) { c.data.push_back(a.data[i]); i++; } while (j < b.data.size()) { c.data.push_back(b.data[j]); j++; } return c; } // 矩阵减法 SparseMatrix sub(SparseMatrix a, SparseMatrix b) { SparseMatrix c; if (a.m != b.m || a.n != b.n) { // 当两个矩阵的行列数不相同时,无法进行减法运算 cout << "Error: The two matrices can't be subtracted." << endl; return c; } c.m = a.m; c.n = a.n; int i = 0, j = 0; while (i < a.data.size() && j < b.data.size()) { // 合并两个矩阵的非零元素 if (a.data[i][0] < b.data[j][0] || (a.data[i][0] == b.data[j][0] && a.data[i][1] < b.data[j][1])) { c.data.push_back(a.data[i]); i++; } else if (a.data[i][0] > b.data[j][0] || (a.data[i][0] == b.data[j][0] && a.data[i][1] > b.data[j][1])) { c.data.push_back({b.data[j][0], b.data[j][1], -b.data[j][2]}); j++; } else { if (a.data[i][2] - b.data[j][2] != 0) { c.data.push_back({a.data[i][0], a.data[i][1], a.data[i][2] - b.data[j][2]}); } i++; j++; } } while (i < a.data.size()) { c.data.push_back(a.data[i]); i++; } while (j < b.data.size()) { c.data.push_back({b.data[j][0], b.data[j][1], -b.data[j][2]}); j++; } return c; } // 矩阵乘法 SparseMatrix mul(SparseMatrix a, SparseMatrix b) { SparseMatrix c; if (a.n != b.m) { // 当第一个矩阵的列数不等于第二个矩阵的行数时,无法进行乘法运算 cout << "Error: The two matrices can't be multiplied." << endl; return c; } c.m = a.m; c.n = b.n; vector<vector<int>> bt(b.n); // 存储 b 矩阵的转置矩阵 for (int i = 0; i < b.data.size(); i++) { bt[b.data[i][1]].push_back(i); } for (int i = 0; i < a.m; i++) { // 计算 c 矩阵的非零元素 vector<int> c_row(c.n); for (int j = 0; j < a.data.size(); j++) { int k = a.data[j][1]; for (int l = 0; l < bt[k].size(); l++) { int p = bt[k][l]; if (b.data[p][0] == k) { c_row[b.data[p][1]] += a.data[j][2] * b.data[p][2]; } } } for (int j = 0; j < c_row.size(); j++) { if (c_row[j] != 0) { c.data.push_back({i, j, c_row[j]}); } } } return c; } // 矩阵转置 SparseMatrix transpose(SparseMatrix a) { SparseMatrix b; b.m = a.n; b.n = a.m; b.data.resize(a.data.size()); vector<int> count(a.n); // 存储每一列非零元素的个数 for (int i = 0; i < a.data.size(); i++) { count[a.data[i][1]]++; } vector<int> index(a.n); // 存储每一列第一个非零元素在 b.data 中的位置 for (int i = 1; i < a.n; i++) { index[i] = index[i - 1] + count[i - 1]; } for (int i = 0; i < a.data.size(); i++) { int j = a.data[i][1]; b.data[index[j]] = {j, a.data[i][0], a.data[i][2]}; index[j]++; } return b; } int main() { SparseMatrix a = {3, 4, {{0, 1, 1}, {1, 2, 2}, {2, 0, 3}, {2, 3, 4}}}; SparseMatrix b = {4, 3, {{0, 1, 1}, {1, 0, 2}, {2, 1, 3}, {2, 2, 4}}}; SparseMatrix c = add(a, b); SparseMatrix d = sub(a, b); SparseMatrix e = mul(a, b); SparseMatrix f = transpose(a); for (int i = 0; i < c.data.size(); i++) { cout << c.data[i][0] << " " << c.data[i][1] << " " << c.data[i][2] << endl; } cout << endl; for (int i = 0; i < d.data.size(); i++) { cout << d.data[i][0] << " " << d.data[i][1] << " " << d.data[i][2] << endl; } cout << endl; for (int i = 0; i < e.data.size(); i++) { cout << e.data[i][0] << " " << e.data[i][1] << " " << e.data[i][2] << endl; } cout << endl; for (int i = 0; i < f.data.size(); i++) { cout << f.data[i][0] << " " << f.data[i][1] << " " << f.data[i][2] << endl; } return 0; } ``` 其中,稀疏矩阵的存储方式为三元组 (i, j, value),表示矩阵中第 i 行第 j 列的元素值为 value。在加法和减法运算中,需要按照行优先的顺序合并两个矩阵的非零元素;在乘法运算中,需要先将第二个矩阵转置,然后按照稀疏矩阵乘法的定义计算。在转置运算中,需要按照列优先的顺序将矩阵中的非零元素存储到转置矩阵中。

最新推荐

recommend-type

pre_o_1csdn63m9a1bs0e1rr51niuu33e.a

pre_o_1csdn63m9a1bs0e1rr51niuu33e.a
recommend-type

matlab建立计算力学课程的笔记和文件.zip

matlab建立计算力学课程的笔记和文件.zip
recommend-type

FT-Prog-v3.12.38.643-FTD USB 工作模式设定及eprom读写

FT_Prog_v3.12.38.643--FTD USB 工作模式设定及eprom读写
recommend-type

matlab基于RRT和人工势场法混合算法的路径规划.zip

matlab基于RRT和人工势场法混合算法的路径规划.zip
recommend-type

matlab基于matlab的两步定位软件定义接收机的开源GNSS直接位置估计插件模块.zip

matlab基于matlab的两步定位软件定义接收机的开源GNSS直接位置估计插件模块.zip
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

SPDK_NVMF_DISCOVERY_NQN是什么 有什么作用

SPDK_NVMF_DISCOVERY_NQN 是 SPDK (Storage Performance Development Kit) 中用于查询 NVMf (Non-Volatile Memory express over Fabrics) 存储设备名称的协议。NVMf 是一种基于网络的存储协议,可用于连接远程非易失性内存存储器。 SPDK_NVMF_DISCOVERY_NQN 的作用是让存储应用程序能够通过 SPDK 查询 NVMf 存储设备的名称,以便能够访问这些存储设备。通过查询 NVMf 存储设备名称,存储应用程序可以获取必要的信息,例如存储设备的IP地址、端口号、名称等,以便能
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。