日常编程小问题之(矩阵乘法的实现C)

  • 矩阵乘法:

根据线代相关知识矩阵乘法公式可以总结为:设A为m*n 的矩阵,B为n*p的矩阵,那么称矩阵C = A*B (m*p)为矩阵AB的乘积,其中矩阵C中的第i行第j列元素可以表示为:

 

案例如下:

  • 代码如下 :

详细解析可见代码注释

#include <stdio.h>

int main(void){
	
	int i,j,k;
	int m1[2][2],m2[2][2],m[2][2];  //简单起见此处采用2*2矩阵 
    
	//为需要相乘的两个矩阵赋值:
    
    printf("请输入第一个矩阵:\n");
    for(i=0;i<2;i++){
        for(j=0;j<2;j++){
            scanf("%d",&m1[i][j]); 
        } 
    } 
     
  
    printf("请输入第二个矩阵:\n");
    
    for(i=0;i<2;i++){
        for(j=0;j<2;j++){
            scanf("%d",&m2[i][j]); 
        } 
    }
    
    //矩阵C初始化
    for(i=0;i<2;i++){
        for(j=0;j<2;j++){
            m[i][j] = 0; 
        } 
    }	 
   
    //矩阵相乘过程采用三重循环,根据乘法公式C矩阵处于第i行,第j列元素是由A矩阵第i行
	//B矩阵的第j列元素相乘加和得到的,通过两层for循环进行控制 ,第三层for实现求和 
    for(i=0;i<2;i++){
        for(j=0;j<2;j++){
            for(k=0;k<2;k++){
                m[i][j]=m[i][j]+m1[i][k]*m2[k][j]; 
            } 
        } 
    }
    
	printf("相乘结果是:\n"); 
    for(i=0;i<2;i++){
        for(j=0;j<2;j++){
            printf("%d ",m[i][j]); 
        } 
        printf("\n"); 
    } 
	return 0;
} 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值