您的位置:首页 > 其它

矩阵相乘(C案例)

2016-05-14 11:03 756 查看
在主函数中输入m和n ,n<=5,m>0

分别定义矩阵A(m X n),B(n X m)和C(m X m )

从键盘读入矩阵A和B中元素的值。

调用自定义子函数multiply()计算矩阵C=A XB

并在主函数中输出矩阵C。

例如:

Input m and n (1~5):4  3
Input A:
1  2  3
4  5  6
7  8  9
10 11 12
Input B:
1  2  3  4
4  5  6  8
7  8  9  10
C=A*B is:
30   36    42     50
66   81    96     116
102  126   150    182
138  171   204    248


#include "stdafx.h"

void multiply(int (*A)[5],int (*B)[5],int m,int n,int (*C)[5])
{
int i,j,k,l;

for (k=0;k<m;k++)
for (l=0;l<m;l++)
for (j=0;j<n;j++)
*(*(C+k)+l)+=(*(*(A+k)+j) * *(*(B+j)+l));
}

void main()
{
int Amn[5][5]={},Bnm[5][5]={},Cmm[5][5]={},m,n,i,j;
printf("Input m and n (1~5):");
scanf("%d %d",&m,&n);

printf("Input A:\n");
for(i=0;i<m;i++)
for (j=0;j<n;j++)
scanf("%d",&Amn[i][j]);

printf("Input B:\n");
for(i=0;i<n;i++)
for (j=0;j<m;j++)
scanf("%d",&Bnm[i][j]);

multiply(Amn,Bnm,m,n,Cmm);
printf("C=A x B is\n");
for (i=0;i<m;i++)
{
for (j=0;j<m;j++)
printf("%-5d ",Cmm[i][j]);
printf("\n");
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: