L1-048 矩阵A乘以B (15分)(c语言)

题目来源: PTA 团体程序设计天梯赛-练习集 L1-048 矩阵A乘以B (15分)
题目如下:
给定两个矩阵A和B,要求你计算它们的乘积矩阵AB。需要注意的是,只有规模匹配的矩阵才可以相乘。即若A有Ra行、Ca列,B有R​b行、C​b列,则只有C​a与R​b相等时,两个矩阵才能相乘。
输入格式:
输入先后给出两个矩阵A和B。对于每个矩阵,首先在一行中给出其行数R和列数C,随后R行,每行给出C个整数,以1个空格分隔,且行首尾没有多余的空格。输入保证两个矩阵的R和C都是正数,并且所有整数的绝对值不超过100。
输出格式:
若输入的两个矩阵的规模是匹配的,则按照输入的格式输出乘积矩阵AB,否则输出Error: Ca != Rb,其中Ca是A的列数,Rb是B的行数。

输入样例1:

2 3
1 2 3
4 5 6
3 4
7 8 9 0
-1 -2 -3 -4
5 6 7 8

输出样例1:

2 4
20 22 24 16
53 58 63 28

输入样例2:

3 2
38 26
43 -5
0 17
3 2
-11 57
99 68
81 72

输出样例2:

Error: 2 != 3

放代码:

#include
#include
#include
#include
int main(){
	int a,b,c,d,h[100][100],l[100][100],o[100][100],m,i,j;
	scanf("%d %d",&a,&b);
	memset(o,0,sizeof(o));
	for(i=0;i<a;i++){
		for(j=0;j<b;j++){
			scanf("%d",&h[i][j]);
		}
	}
	scanf("%d %d",&c,&d);
	for(i=0;i<c;i++){
		for(j=0;j<d;j++){
			scanf("%d",&l[i][j]);
		}
	}
	if(b!=c)
		printf("Error: %d != %d\n",b,c);
	else{
		printf("%d %d\n",a,d);
		for(i=0;i<a;i++){
			for(j=0;j<d;j++){
				for(m=0;m<b;m++)
				o[i][j]+=h[i][m]*l[m][j];
				printf("%d",o[i][j]);
				if(j<d-1)
				 	printf(" ");
				else
					printf("\n");
			}
		}
	}
	return 0;
}

你可能感兴趣的:(c语言,算法,程序设计,c++)