【C语言】矩阵乘法

相信你是最棒哒!!!

文章目录

题目描述

正确代码

总结


题目描述

根据两个矩阵相乘的法则:

矩阵A乘矩阵B,得矩阵C,方法是A的第一行元素分别对应乘以B的第一列元素各元素,相加得C11,A的第一行元素对应乘以B的第二列个元素,相加得C12,以此类推,C的第二行元素为A的第二行元素按上面方法与B相乘所得结果,以此类推。

现有矩阵A和B,都是n×n阶。请你输出相乘后的矩阵C。
输入描述

正整数n(n<15),接着输入两个n*n矩阵的各元素。
输出描述

输出两个矩阵的积。
样例输入

tab-topic-content-item-content 复制代码
3
2 5 6
8 10 9
12 4 3
5 6 13
14 5 36
4 8 17

样例输出

tab-topic-content-item-content 复制代码
104 85 308 
216 170 617 
128 116 351 

正确代码

注释版

复制代码
#include <stdio.h> 

int a[100][100], b[100][100], c[100][100]; // 定义三个100x100的整型二维数组,分别用于存储矩阵a、b和结果矩阵c

int main() 
{
    int i, j, k; // i、j、k,用于循环计数
    int n; // 定义一个整型变量n,用于存储矩阵的行数和列数
    scanf("%d", &n); // 读取用户输入的矩阵大小n

    // 读取矩阵a的元素
    for(i = 0; i < n; i++)
    {
        for(j = 0; j < n; j++)
            scanf("%d", &a[i][j]); // 读取矩阵a的第i行第j列的元素
    }

    // 读取矩阵b的元素
    for(i = 0; i < n; i++)
    {
        for(j = 0; j < n; j++)
            scanf("%d", &b[i][j]); // 读取矩阵b的第i行第j列的元素
    }

    // 计算矩阵a和b的乘积,结果存储在矩阵c中
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++) {
            for (int k = 0; k < n; k++) {
                c[i][j] += a[i][k] * b[k][j]; // 根据矩阵乘法的定义,计算c的第i行第j列的元素
            }
        }
    }

    // 打印矩阵c的元素
    for(i = 0; i < n; i++)
    {
        for(j = 0; j < n; j++)
        {
            printf("%d ", c[i][j]); // 打印矩阵c的第i行第j列的元素
        }
        printf("\n"); // 每打印完一行后换行
    }

    return 0; // 返回0,表示程序正常结束
}

简洁版

复制代码
#include <stdio.h>
int a[20][20], b[20][20], c[20][20];
int main()
{
	int i, j, k, n;
	scanf("%d", &n);
	for (i = 0; i < n; i++)
		for (j = 0; j < n; j++)
			scanf("%d", &a[i][j]);

	for (i = 0; i < n; i++)
		for (j = 0; j < n; j++)
			scanf("%d", &b[i][j]);

	for (i = 0; i < n; i++)
		for (j = 0; j < n; j++)
			for (k = 0; k < n; k++)
				c[i][k] += a[i][j] * b[j][k];

	for (i = 0; i < n; i++) {
		for (j = 0; j < n; j++)
			printf("%d ", c[i][j]);
		printf("\n");
	}

	
	return 0;
}

总结

重要一步 ----> c[i][k] += a[i][j] * b[j][k];

相关推荐
向阳花开_miemie17 分钟前
Android音频学习(二十二)——音频接口
学习·音视频
艾莉丝努力练剑19 分钟前
【C++STL :stack && queue (一) 】STL:stack与queue全解析|深入使用(附高频算法题详解)
linux·开发语言·数据结构·c++·算法
胡萝卜3.034 分钟前
深入理解string底层:手写高效字符串类
开发语言·c++·学习·学习笔记·string类·string模拟实现
kyle~34 分钟前
计算机系统---CPU的进程与线程处理
linux·服务器·c语言·c++·操作系统·计算机系统
CoovallyAIHub35 分钟前
ICLR 2026 惊现 SAM 3,匿名提交,实现“概念分割”,CV领域再迎颠覆性突破?
深度学习·算法·计算机视觉
fanstering41 分钟前
腾讯混元P3-SAM: Native 3D Part Segmentation
笔记·学习·3d·点云
IT古董43 分钟前
【第五章:计算机视觉-计算机视觉在工业制造领域中的应用】1.工业缺陷分割-(2)BiseNet系列算法详解
算法·计算机视觉·制造
电鱼智能的电小鱼1 小时前
服装制造企业痛点解决方案:EFISH-SBC-RK3588 预测性维护方案
网络·人工智能·嵌入式硬件·算法·制造
yan8626592461 小时前
于 C++ 的虚函数多态 和 模板方法模式 的结合
java·开发语言·算法
小此方1 小时前
C语言自定义变量类型结构体理论:从初见到精通(下)
c语言·数据结构·算法