一本通网站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;
	}
}
相关推荐
GIS阵地几秒前
QgsDataSourceUri解析
数据库·c++·qt·开源软件·qgis
一杯美式 no sugar3 分钟前
C++入门基础
开发语言·c++
AMoon丶10 分钟前
Golang--内存管理
开发语言·后端·算法·缓存·golang·os
美式请加冰16 分钟前
异常的介绍和使用
开发语言·c++
zl_vslam22 分钟前
SLAM中的非线性优-3D图优化之相对位姿Between Factor-四元数(十二)
人工智能·算法·计算机视觉
coding者在努力30 分钟前
算法竞赛中根据数据规模猜测算法
c++·算法·stl·时间复杂度
jing-ya32 分钟前
day 59 图论part10
java·开发语言·数据结构·算法·图论
love530love33 分钟前
ComfyUI-3D-Pack:Windows 下手动编译 mesh_inpaint_processor C++ 加速模块
c++·人工智能·windows·python·3d·hunyuan3d·comfyui-3d-pack
楼田莉子40 分钟前
C++高并发内存池:内存池调优与测试
c++·后端·哈希算法·visual studio
阿Y加油吧44 分钟前
力扣打卡——搜索二维矩阵、相交链表
线性代数·leetcode·矩阵