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]; } } } } 运行结果: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。 您可能感兴趣的文章:
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |