通过矩阵乘积计算公式计算矩阵相乘并且输出结果
#include<stdio.h>
#define ROW 2
#define COL 3
//函数功能:计算矩阵相乘之积,结果存于二位数组当中
void Multiple_Matrix(int a[ROW][COL],int b[COL][ROW],int c[ROW][ROW])
{
int i,j,k;
for(i=0;i<ROW;i++)
{
for(j=0;j<ROW;j++)
{
c[i][j]=0; //二位数组的初始化
for(k=0;k<COL;k++)
{
c[i][j]+=a[i][k]*b[k][j];
}
}
}
}
//函数功能:输出矩阵中元素
void Print_Matrix(int d[ROW][ROW])
{
int i,j;
for(i=0;i<ROW;i++) //写入和输出一样,都是先按照行开始,自左向右进行输出
{
for(j=0;j<ROW;j++)
{
printf("%6d",d[i][j]);
}
printf("\n"); //需要换行"勾勒"矩阵的形状
}
}
int main(void)
{
int a[ROW][COL],b[COL][ROW],c[ROW][ROW],i,j;
//写入矩阵a
printf("Input 2*3 matrix a:\n");
for(i=0;i<ROW;i++)
{
for(j=0;j<COL;j++)
{
scanf("%d",&a[i][j]); //每行自左到右写入
}
}
//写入矩阵b;
printf("Input 3*2 matrix b:\n");
for(i=0;i<COL;i++)
{
for(j=0;j<ROW;j++)
{
scanf("%d",&b[i][j]); //每行自左到右写入
}
}
Multiple_Matrix(a,b,c);
Print_Matrix(c);
return 0 ;
}