2021-11-10

Problem B: Matrix Problem (II) : Array Practice
求两个矩阵A、B的和。根据矩阵加法的定义,只有同阶的矩阵才能相加。可以确保所有运算结果都在int类型的范围之内。

Input
输入数据为多个矩阵,每个矩阵以两个正整数m和n开始,满足0<m,n<=100,接下来为一个m行n列的矩阵A。当输入的m和n均为0时,表示输入数据结束

Output
对输入的矩阵两两相加:第1个和第2个相加、第3个和第4个相加……按顺序输出矩阵相加的结果:每行两个元素之间用一个空格分开,每行最后一个元素之后为一个换行,在下一行开始输出矩阵的下一行。

若输入的矩阵不为偶数个,最后剩余的矩阵不产生任何输出。

不满足矩阵加法定义的数据输出“Not satisfied the definition of matrix addition!”

每两组输出之间用一个空行分隔开`
#include <stdio.h>
#include <stdlib.h>
#include<string.h>
#define LEN 100
void input(int a[][LEN],int m,int n)
{
for(int i=0; i<m; i++)
for(int j=0; j<n; j++)
scanf("%d",&a[i][j]);
}
void xiangjia(int a[][LEN],int b[][LEN],int m,int n)
{
for(int i=0; i<m; i++)
for(int j=0; j<n; j++)
a[i][j]+=b[i][j];
}
void output(int a[][LEN],int m,int n)
{
for(int i=0; i<m; i++)
{
for(int j=0; j<n; j++)
printf("%d “,a[i][j]);
putchar(’\n’);
}
}
int main()
{
freopen(“D:\Desktop\in.txt”,“r”,stdin);
int m1,n1,m2,n2;
int A[LEN][LEN],B[LEN][LEN];
scanf(”%d%d",&m1,&n1);
while(m1!=0&&n1!=0)
{
input(A,m1,n1);
scanf("%d%d",&m2,&n2);
if(m20&&n20)
return;
if(m1m2&&m2n2)
{
input(B,m2,n2);
xiangjia(A,B,m1,n1);
output(A,m1,n1);s
}
else
printf(“NO”);
putchar(’\n’);
scanf("%d%d",&m1,&n1);
}

}
`


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值