【山科OJ】Problem B: Matrix Problem (II) : Array Practice

Description

求两个矩阵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!”

每两组输出之间用一个空行分隔开。

Sample Input

3 3

1 2 3

4 5 6

7 8 9

3 3

9 8 7

6 5 4

3 2 1

3 3

1 1 1

1 1 1

1 1 1

2 2 2

2 2 2

1 1

0

0 0

Sample Output

10 10 10

10 10 10

10 10 10

Not satisfied the definition of matrix addition!

HINT

矩阵的加法就是对应位置上的元素相加。

Append Code

#include<stdio.h>
 
void inputMtr(int m,int n,int a[101][101])
{
    for(int i=0; i<m; i++)
    {
        for(int j=0; j<n; j++)
        {
            scanf("%d",&a[i][j]);
        }
    }
}
 
void output(int m,int n,int a[101][101])
{
    for(int i=0; i<m; i++)
    {
        for(int j=0; j<n; j++)
        {
            if(j!=0)printf(" %d",a[i][j]);
            else printf("%d",a[i][j]);
        }
        if(i!=m-1)printf("\n");
    }
}
void AddMtr(int m,int n,int a[101][101],int x,int y,int b[101][101])
{
    if(m==x && n==y)
    {
        for(int i=0; i<m; i++)
        {
            for(int j=0; j<n; j++)
            {
                b[i][j]=a[i][j]+b[i][j];
            }
        }
        output(x,y,b);
    }
    else printf("Not satisfied the definition of matrix addition!");
}
int main()
{
    int a[101][101]= {0},b[101][101]= {0};
    int m,n,x,y,flag=0;
    scanf("%d %d",&m,&n);
    while(m&&n)
    {
        inputMtr(m,n,a);
        if(flag%2!=0)
        {
            if(flag!=1)printf("\n\n");
            AddMtr(m,n,a,x,y,b);
        }
        else
        {
            for(int i=0; i<m; i++)
            {
                for(int j=0; j<n; j++)
                {
                    b[i][j]=a[i][j];
                }
            }
            x=m;
            y=n;
        }
        flag++;
        scanf("%d %d",&m,&n);
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值