矩阵乘法.

矩阵乘法的前提条件:行列对应(矩阵A3行四列 对应 矩阵B四行3列)

最后运算矩阵C第一个数等于A的第一行每一个数乘以B第一列每一个数

C[0][0]=A[0] [0] * B[0] [0]+A[0] [1] * B[1] [0]+A[0] [2] * B[2] [0]+A[0] [3] * B[3] [0]

C[0] [1]同理

计算出每一个C矩阵的数值,然后输出

  1. 先输入矩阵A的每一个数值,逐行输入,然后保存在一个多维数组arr1[ ][ ]中
  2. 矩阵B同理,保存在数组arr2中
  3. 计算矩阵C的每一个数值,利用嵌套循环加法的方式    sum = sum + arr1[i][m] * arr2[m][j];   计算出A的每一行乘以B的每一列得出C的第一个数值,然后循环计算出每一个数值,存入在数组arr3中
  4. 最后输出arr3 
#include<stdio.h>
#define ROW 3 //行 
#define COL 3 //列 
#define MID 4
int main()
{
	
	printf("下面输入分别输入一个3行4列的矩阵A和4行3列的矩阵B\n  ") ;
	int arr1[ROW][MID] = { 0 }; // 3行4列 
	int arr2[MID][COL] = { 0 }; // 4行3列 
	int arr3[ROW][COL] = { 0 }; // 3行3列 
	int i = 0;
	int j = 0;
	int m = 0;
	printf("第一个矩阵A\n" );
	for (i = 0; i < ROW; i++) //输入三次,变成三行 
	{
		printf("第一个矩阵的%d行\n", i);
		for (j = 0; j < MID; j++)   //输入四次,变成四列 
		{
			scanf("%d", &arr1[i][j]); //第一次一直读入从arr1[0][0]到 arr1[0][4] 
		}
	}
	printf("第二个矩阵B\n");
	for (i = 0; i < MID; i++)  //输入四次,变成四行 
	{
		printf("第二个矩阵第%d行\n", i);
		for (j = 0; j < COL; j++)   //输入三次,变成三列 
		{
			scanf("%d", &arr2[i][j]);//第一次一直读入从arr2[0][0]到 arr2[0][4] 
		}
	}
	printf("第三个矩阵C:\n"); //三行三列 
	for (i = 0; i < ROW; i++)//从arr[0][0] 开始存入数据 
	{
		for (j = 0; j < COL; j++)
		{
			int sum = 0;    //临时存储 
			for (m = 0; m < MID; m++)
			{
				sum = sum + arr1[i][m] * arr2[m][j];  //arr1[0][m] * arr2[m][0];
			}
			arr3[i][j] = sum; //计算第一个值存入矩阵,然后重新循环变成arr3[0][1] 
		}
	}
	for (i = 0; i < ROW; i++) //输出矩阵 
	{
		for (j = 0; j < COL; j++)
		{
			printf("%3d  ", arr3[i][j]);//输出每一个数值 
		}
		printf("\n");
	}
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值