大佬教程收集整理的这篇文章主要介绍了C语言实现两个矩阵相乘,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
本文实例为大家分享了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语言实现两个矩阵相乘所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。