加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 创业 > C语言 > 正文

C语言实现两个矩阵相乘

发布时间:2020-12-15 00:51:07 所属栏目:C语言 来源:网络整理
导读:本文实例为大家分享了C语言实现两个矩阵相乘的具体代码,供大家参考,具体内容如下 程序功能:实现两个矩阵相乘的C语言程序,并将其输出 代码如下: #include "stdafx.h"#include "windows.h"void Multi(int * left,int * right,int * result,int f1,int f2,

本文实例为大家分享了C语言实现两个矩阵相乘的具体代码,供大家参考,具体内容如下

程序功能:实现两个矩阵相乘的C语言程序,并将其输出

代码如下:

#include "stdafx.h"
#include "windows.h"
void Multi(int * left,int * right,int * result,int f1,int f2,int s1,int s2);

int main()
{
 int i,j;
 int a[4][3] = 
 { {1,2,3},{4,5,6},{7,8,9},{1,3}};
 int b[3][3] =
 { { 1,3 },{ 4,6 },9} };
 //c矩阵为a矩阵与b矩阵的乘积
 int c[4][3];
 //计算两个矩阵相乘
 Multi(a[0],b[0],c[0],4,3,3);
 //输出c矩阵
 for (i = 0; i < 4; i++)
 {
  for(j=0;j<3;j++)
   printf("%4d ",c[i][j]);
  printf("n");
 }
 system("pause");
 return 0;
}

//矩阵相乘算法,最后四个参数是两个相乘的矩阵的行数和列数
void Multi(int * left,int s2)
{
 //int a[f1][f2],b[s1][s2],c[f1][s2];
 //a[i][j]==a[i*f2+j]
 //由矩阵相乘,要求f2=s1,以下用f2
 for (int i = 0; i < f1; i++) //i表示第i行
 {
  for (int j = 0; j < s2; j++) //j表示第j列
  {
   result[i*f2 + j] = 0;  //在这里 result[i][j] = result[i*f2+j];
   for(int p=0;p<f2;p++)
   {
    result[i*f2 + j] +=left[i*f2+p]*right[p*f2+j];
   }
  }
 }
}

运行结果:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。

您可能感兴趣的文章:

  • C语言矩阵连乘 (动态规划)详解
  • C语言实现稀疏矩阵
  • C语言实现矩阵翻转(上下翻转、左右翻转)
  • C语言 经典题目螺旋矩阵 实例详解
  • C语言求矩阵的各列元素之和的代码示例
  • C语言解决螺旋矩阵算法问题的代码示例
  • C语言科学计算入门之矩阵乘法的相关计算

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读