栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

用C语言实现矩阵相乘SWUSTOJ74

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

用C语言实现矩阵相乘SWUSTOJ74

题目描述:

 

矩阵显然需要用到C语言的二维数组来解决

这里要注意,输入的时候是一个矩阵输入完了过后再输入另一个矩阵,并且一次输入只能读取一个数,这样我们就需要一个for循环来依次分别对啊,b两个数进行输入。

 

笔者在写这个代码之前也是非常的纠结这个循环应该怎么去建立,知道我自己亲手用笔去画了一下这个过程后再真正发现这个代码里面的规律

我们通过计算结果数列的一个内部过程来推算整体,可以发现如下规律

 

 我们纵向来看这些数的时候可以发现很多规律,在分别单独计算c中每一个数的时候,我们在其中去分别寻找有没有某些列是完全相同的数字,这样我们就可以把他们作为最外层的循环,找完相同的过后再去找那些不相同的,可以发现都是以同样的递增方式并且是同样的数字进行递增,那么这样我们就将其作为循环的最内层,即k层

 

 这里的输出也需要注意,输出有每三个换行的情况,需要格外注意一下。

源代码:

#include

int main()
{
    int i = 0;
    int j = 0;
    int k = 0;
    int a[3][3] = { 0 };
    int b[3][3] = { 0 };
    int c[3][3] = { 0 };
    for (i = 0; i <= 2; i++)
    {
        for (j = 0; j <= 2; j++)
        {
            scanf("%d", &a[i][j]);//注意这里的取地址符号不能掉
        }
    }
    for (i = 0; i <= 2; i++)
    {
        for (j = 0; j <= 2; j++)
        {
            scanf("%d", &b[i][j]);
        }
    }
    for (i = 0; i <= 2; i++)
    {
        for (j = 0; j <= 2; j++)
        {
            for (k = 0; k <= 2; k++)
            {
                c[i][j] = c[i][j] + a[i][k] * b[k][j];
            }
        }
    }
    for (i = 0; i <= 2; i++)
    {
        for (j = 0; j <= 2; j++)
        {
            printf("%d ", c[i][j]);
        }
        printf("n");
    }
    return 0;

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/512858.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号