ZZULI OJ 1127: 矩阵乘积 C++ (带你看懂每一步)

这篇博客介绍了矩阵乘法的基础知识,并提供了一个C++程序来计算两个矩阵的乘积。博主强调了理解线性代数中矩阵乘法的重要性,并提供了详细的代码解释,包括先行后列的遍历方式和如何计算每个乘积矩阵元素。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1127: 矩阵乘积

题目描述

        计算两个矩阵A和B的乘积。

输入

        第一行三个正整数m、p和n,0<=m,n,p<=10,表示矩阵A是m行p列,矩阵B是p行n列;
接下来的m行是矩阵A的内容,每行p个整数,用空格隔开;
最后的p行是矩阵B的内容,每行n个整数,用空格隔开。

输出

         输出乘积矩阵:输出占m行,每行n个数据,以空格隔开。

样例输入

2 3 4

1 0 1
0 0 1

1 1 1 3
4 5 6 7
8 9 1 0

样例输出

9 10 2 3
8 9 1 0

题目链接    ZZULI OJ 1127

说明

         要做这题,最好要学过线性代数,有矩阵知识的相关基础 ,由于专业较特殊,博主大一上学期学完了线性代数,这里来科普一下矩阵相乘的相关知识点

  了解了以上内容,这道题就不难解决了,只需套用用公式

题解及注释(C++)

#include<iostream>
using namespace std;
int main()
{
	int a[10][10],b[10][10];  //数组a为前面那个数组,b为后面那个数组 
	int m,p,n,sum=0,k=0;   //sum用于每行每列对应元素相乘再相加,K用于计数 
	cin>>m>>p>>n;
	for(int i=0;i<m;i++)
	  for(int j=0;j<p;j++)
	    cin>>a[i][j];     //读入前面那个数组 
	for(int i=0;i<p;i++)
	  for(int j=0;j<n;j++)
	    cin>>b[i][j];    //读入后面那个数组
	
	for(int i=0;i<m;i++)    //先行后列 
	    for(int j=0;j<n;j++)
	    {   
		    for(int s=0;s<p;s++)	//每行或没列的总个数 
	            sum+=a[i][s]*b[s][j];   //对应元素相乘再相加 
	        cout<<sum<<" ";     k++;    //输出相乘矩阵对应元素后,计数器++            
	        if(k%n==0) cout<<endl;     //计数器达到行数,换行 
			sum=0;                  //计算下一元素,sum归零 
        }     
	return 0; 
}

注意

        (1)数组下标从0开始,与矩阵不同,矩阵的A11对应为数组的A00

        (2)因为先是第一行乘以第一列,再第一行乘以第二列,然后第一行乘以第三列......所以是先行后列进行对应元素相乘再相加 

                                   创作不易,点个赞再走吧(。・∀・)ノ

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

挑不动

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值