c语言求2矩阵相乘函数,可以自定义矩阵的阶次
1个回答
展开全部
#include<stdio.h>
#define N 2
#define M 3
#define P 2
//a[N][M] * b[M][P] =c[N][P]
void matric(int x[][M],int y[][P],int z[][P])
{
int i,j,k;
for(i=0;i<N;i++)
for(j=0;j<P;j++)
for(k=0;k<M;k++)
z[i][j]+=x[i][k]*y[k][j];
}
void main()
{
int i,j;
int a[2][3]={{3,4,5},{2,2,4}};
int b[3][2]={{2,3},{5,6},{3,4}};
int c[2][2]={{0,0},{0,0}};
matric(a,b,c);
for(i=0;i<N;i++)
for(j=0;j<P;j++)
{
if(j%P==0) printf("\n");
printf("%d ",c[i][j]);
}
printf("\n");
}
#define N 2
#define M 3
#define P 2
//a[N][M] * b[M][P] =c[N][P]
void matric(int x[][M],int y[][P],int z[][P])
{
int i,j,k;
for(i=0;i<N;i++)
for(j=0;j<P;j++)
for(k=0;k<M;k++)
z[i][j]+=x[i][k]*y[k][j];
}
void main()
{
int i,j;
int a[2][3]={{3,4,5},{2,2,4}};
int b[3][2]={{2,3},{5,6},{3,4}};
int c[2][2]={{0,0},{0,0}};
matric(a,b,c);
for(i=0;i<N;i++)
for(j=0;j<P;j++)
{
if(j%P==0) printf("\n");
printf("%d ",c[i][j]);
}
printf("\n");
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询