一本通网站1125题:矩阵乘法

学过线性代数的朋友应该都不陌生矩阵的乘法,3x2的矩阵和2x3的矩阵相乘,最后得到的是3x3的矩阵,也就是题目中的n x k的矩阵。包括题目只给了三个变量,因为只有n x m的矩阵才能和m x k的矩阵相乘。就是前一个矩阵的列和后一个矩阵的行必须是相等的才可以相乘,这些就是线性代数的知识了,不过多赘述。

代码的话,定义两个二维数组,分别存储矩阵A和B,我在写的时候,下意识的想当然了,按线性代数里的计算方法写,结果越写越乱,然后又看了一眼题干,不是已经把公式给你了嘛,严格按照公式来就可以了,和上一个题,矩阵加法一样,我们可以不用定义第三个二维数组存储矩阵C,每求一个位置的数字直接打印就可以了。最后得到的就是矩阵C。

cpp 复制代码
#include<iostream>
using namespace std;
int main()
{
	int n = 0, m = 0, k = 0;
	cin >> n >> m >> k;
	//初始化矩阵A
	int** arr1 = new int* [n];
	for (int i = 0; i < n; i++)
	{
		arr1[i] = new int[m];
	}
	//初始化矩阵B
	int** arr2 = new int* [m];
	for (int i = 0; i < m; i++)
	{
		arr2[i] = new int[k];
	}
	//读入矩阵A的数据
	for (int i = 0; i < n; i++)
	{
		for (int j = 0; j < m; j++)
		{
			cin >> arr1[i][j];
		}
	}
	//读入矩阵B的数据
	for (int i = 0; i < m; i++)
	{
		for (int j = 0; j < k; j++)
		{
			cin >> arr2[i][j];
		}
	}
	//定义一个变量,存储矩阵C[i][j]的值,计算结果后直接打印。
	int num = 0;
	for (int i = 0; i < n; i++)
	{
		for (int j = 0; j < k; j++)
		{
			num = 0;
            //这个循环求的是C[i][j]位置的值。
			for (int a = 0; a < m; a++)
			{
				num += arr1[i][a] * arr2[a][j];
			}
			cout << num << " ";
		}
		cout << endl;
	}
}
相关推荐
STY_fish_201216 分钟前
P11855 [CSP-J2022 山东] 部署
算法·图论·差分
myw07120516 分钟前
湘大头歌程-Ride to Office练习笔记
c语言·数据结构·笔记·算法
H_BB18 分钟前
算法详解:滑动窗口机制
数据结构·c++·算法·滑动窗口
淀粉肠kk18 分钟前
【C++】封装红黑树实现Mymap和Myset
数据结构·c++
Zero-Talent19 分钟前
“栈” 算法
算法
橘子编程20 分钟前
经典排序算法全解析
java·算法·排序算法
waeng_luo20 分钟前
【鸿蒙开发实战】智能数据洞察服务:待回礼分析与关系维护建议算法
算法·ai编程·鸿蒙
风筝在晴天搁浅20 分钟前
代码随想录 279.完全平方数
算法
不穿格子的程序员24 分钟前
从零开始刷算法——字串与区间类经典题:前缀和 + 单调队列双杀
算法·前缀和·哈希表·双向队列·单调队列
坚持就完事了24 分钟前
十大排序算法
数据结构·算法·排序算法