Description
在数学中,矩阵是一个按照长方阵列排列的复数或实数集合,最早来自于方程组的系数及常数所构成的方阵。这一概念由19世纪英国数学家凯利首先提出。
矩阵是高等代数学中的常见工具,也常见于统计分析等应用数学学科中。在物理学中,矩阵于电路学、力学、光学和量子物理中都有应用;计算机科学中,三维动画制作也需要用到矩阵。 矩阵的运算是数值分析领域的重要问题。将矩阵分解为简单矩阵的组合可以在理论和实际应用上简化矩阵的运算。对一些应用广泛而形式特殊的矩阵,例如稀疏矩阵和准对角矩阵,有特定的快速运算算法。
作为A+B问题,我们在此掌握矩阵的加法运算:
$$ \left( \begin{matrix} a_{11} & a_{12} & a_{13} \\ a_{21} & a_{22} & a_{23} \\ a_{31} & a_{32} & a_{33} \end{matrix}\right) + \left( \begin{matrix} b_{11} & b_{12} & b_{13} \\ b_{21} & b_{22} & b_{23} \\ b_{31} & b_{32} & b_{33} \end{matrix}\right) = \left( \begin{matrix} a_{11} + b_{11} & a_{12}+ b_{12} & a_{13}+ b_{13} \\ a_{21}+ b_{21} & a_{22}+ b_{22} & a_{23}+ b_{23} \\ a_{31}+ b_{31} & a_{32}+ b_{32} & a_{33}+ b_{33} \end{matrix}\right)$$
上式就表示两个3*3
矩阵的加法,聪明的你应该想到n*m
的矩阵运算法则:两个n*m
矩阵A
和B
的和,一样是个n*m
矩阵,其内的各元素为其相对应元素相加后的值。
现在给你两个矩阵A
、B
,请你输出得到的A+B
结果矩阵。
Input
第一行是两个数n
、m
,表示给出两个n
行m
列的矩阵。
下面n
行描述矩阵A
,再下面n
行描述矩阵B
。
详细格式请参考样例。
1 ≤ n ≤ 50
1 ≤ m ≤ 50
0 ≤ |aij| ≤ 105
0 ≤ |bij| ≤ 105
Output
请输出n
行数描述矩阵A+B
。
每行的m
个数用一个空格分隔开,行末不需要空格。
Sample Input
2 3 1 2 3 3 4 5 1 1 0 1 2 0
Sample Output
2 3 3 4 6 5
Hint
请严格按照格式输出,不要输出多余空格。
#include<cstdio>
long long a[55][55],b[55][55];
int main()
{
int n,m;
while(scanf("%d%d",&n,&m)!=EOF)
{
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
scanf("%lld",&a[i][j]);
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
scanf("%lld",&b[i][j]);
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
a[i][j]+=b[i][j];
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
j==m?printf("%lld\n",a[i][j]):printf("%lld ",a[i][j]);
}
}
}
return 0;
}