C语言中如何求两个矩阵的乘积

技术C语言中如何求两个矩阵的乘积这篇文章将为大家详细讲解有关C语言中如何求两个矩阵的乘积,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。分析在数学中,矩阵(Matrix)是

本文将详细说明如何用C语言求两个矩阵的乘积。这篇文章的内容质量很高,所以边肖会分享给大家参考。希望你看完这篇文章后有所了解。

00-1010在数学中,矩阵是按照矩形阵列排列的一组复数或实数。矩阵是高等代数中的常用工具,在统计分析等应用数学学科中也很常见。

C语言中如何求两个矩阵的乘积

矩阵的乘法有以下注意事项:

1.当矩阵a的列数等于矩阵b的行数时,a和b可以相乘。

2.矩阵C的行数等于矩阵A的行数,C的列数等于b的列数。

3.乘积C的第m行和第n列中的元素等于矩阵A的第m行中的元素与矩阵b的第n列中的对应元素的乘积之和。

C语言中如何求两个矩阵的乘积

代码实现:只需要用矩阵乘积的公式就可以找到一个新的矩阵,也就是两个矩阵的乘积。在程序中,还需要判断两个矩阵是否可以相乘。

分析

# includes dio . h

intmain()

{

int line _ a=0;//矩阵行数

int col _ a=0;//矩阵的列数

int line _ b=0;//B矩阵行数

int col _ b=0;//B矩阵的列数

inti=0;

int j=0;

int k=0;

/*获取矩阵A的行数和列数*/

Printf('请输入矩阵的行数和列数\ n ');

scanf('%d%d ',line_a,col _ a);

int matrix _ A[line _ A][col _ A];

/*获取B矩阵的行数和列数*/

Printf('请输入B矩阵的行数和列数\ n ');

scanf('%d%d ',line_b,col _ b);

int matrix _ B[line _ B][col _ B];

if(col_a!=line_b)

{

Printf('错误,矩阵A的列数和矩阵B的行数必须相等!\ n ');

返回0;

}

int matrix _ C[line _ a][col _ b];//C矩阵:a矩阵和b矩阵的乘积。

/*获取矩阵元素*/

for(I=0;iline _ a;(一)

{

Printf('请在矩阵的第%d行输入元素\n ',I);

      for(j = 0; j < col_a; j++)
        {
            scanf("%d", &matrix_A[i][j]);
        }
    }
    /* 获取B矩阵元素 */
    for(i = 0; i< line_b; i++)
    {
        printf("请输入B矩阵第%d行元素\n", i);
        for(j = 0; j < col_b; j++)
        {
            scanf("%d", &matrix_B[i][j]);
        }
    }
    /* 打印矩阵 */
    printf("输入的A矩阵为:\n");
    for(i = 0; i < line_a; i++)
    {
        for(j = 0; j < col_a; j++)
        {
            printf("%d\t", matrix_A[i][j]);
        }
        printf("\n");
    }
    printf("输入的B矩阵为:\n");
    for(i = 0; i < line_b; i++)
    {
        for(j = 0; j < col_b; j++)
        {
            printf("%d\t", matrix_B[i][j]);
        }
        printf("\n");
    }
    /* 求AB的乘积,即矩阵C */
    for(i = 0; i < line_a; i++)
    {
        for(j = 0; j < col_b; j++)
        {
            matrix_C[i][j] = 0; //初始化
            for(k = 0; k < col_a; k++)
              matrix_C[i][j] += matrix_A[i][k] * matrix_B[k][j];
        }
    }
    /* 打印C矩阵 */
    printf("A矩阵乘B矩阵:\n");
    for(i = 0; i < line_a; i++)
    {
        for(j = 0; j < col_b; j++)
        {
            printf("%d\t", matrix_C[i][j]);
        }
        printf("\n");
    }
    return 0;
}

运行结果

C语言中如何求两个矩阵的乘积

关于C语言中如何求两个矩阵的乘积就分享到这里了,希望

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/84018.html

(0)

相关推荐

  • MySQL中如何使用undrop来恢复drop的表

    技术MySQL中如何使用undrop来恢复drop的表小编给大家分享一下MySQL中如何使用undrop来恢复drop的表,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下

    攻略 2021年11月2日
  • 怎么优化JS代码

    技术怎么优化JS代码这篇文章主要讲解了“怎么优化JS代码”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么优化JS代码”吧!1、字符串的拼接 字符串的拼接在我们开发中会经

    攻略 2021年11月18日
  • 抖音刷千粉,抖音刷粉1000人多少钱?

    技术抖音刷千粉,抖音刷粉1000人多少钱?抖音快速增长粉料的方法抖音无疑是目前新媒体中增长粉料最简单、增长最快的平台。从前,成都小甜甜一夜涨粉五百万,后来,灵魂当铺一天涨粉七十五万。这样的涨粉速度在其他平台是难以想象的。

    测评 2021年10月19日
  • Python如何移植到IMX6ULL开发板上

    技术Python如何移植到IMX6ULL开发板上这篇文章主要讲解了“ Python如何移植到IMX6ULL开发板上”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“ Pyth

    攻略 2021年11月23日
  • 如何理解Java通过加密技术保护源代码的方法

    技术如何理解Java通过加密技术保护源代码的方法这篇文章主要讲解了“如何理解Java通过加密技术保护源代码的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何理解Ja

    攻略 2021年10月25日
  • 然后用AFL开始你的第一次Fuzzing

    技术然后用AFL开始你的第一次Fuzzing然后用AFL开始你的第一次Fuzzing,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、前言模糊测试(Fu

    攻略 2021年11月26日