Problem B: Matrix Problem (II) : Array Pratice
Time Limit: 1 Sec Memory Limit: 4 MB
Submit: 1492 Solved: 465
[Submit ][Status ][Web Board]
Description 求两个矩阵A 、B 的和。根据矩阵加法的定义,只有同阶的矩阵才能相加。可以确保所有运算结果都在int 类型的范围之内。
Input 输入数据为多个矩阵,每个矩阵以两个正整数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
#include
int main()
{
//freopen("a.txt","r",stdin);
//freopen("b.txt","w",stdout);
int m,n;
scanf("%d%d",&m,&n);
do
{
int i,j,a[m][n];
for(i=0; i
for(j=0; j
scanf("%d",&a[i][j]);
int e,f;
scanf("%d%d",&e,&f);
int b[e][f];
for(i=0; i
for(j=0; j
scanf("%d",&b[i][j]);
if(e==0&&f==0)
{
return 0;
}
else if(m==e&&n==f)
{
for(i=0;i
{
for(j=0;j
{
if(j!=0)
putchar(' ');
printf("%d",a[i][j]+b[i][j]); }
putchar('\n');
}
putchar('\n');
}
else
{
printf("Not satisfied the definition of matrix addition!\n\n");
}
scanf("%d%d",&m,&n);
}while(m!=0&&n!=0);
return 0;
}
Problem B: Matrix Problem (II) : Array Pratice
Time Limit: 1 Sec Memory Limit: 4 MB
Submit: 1492 Solved: 465
[Submit ][Status ][Web Board]
Description 求两个矩阵A 、B 的和。根据矩阵加法的定义,只有同阶的矩阵才能相加。可以确保所有运算结果都在int 类型的范围之内。
Input 输入数据为多个矩阵,每个矩阵以两个正整数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
#include
int main()
{
//freopen("a.txt","r",stdin);
//freopen("b.txt","w",stdout);
int m,n;
scanf("%d%d",&m,&n);
do
{
int i,j,a[m][n];
for(i=0; i
for(j=0; j
scanf("%d",&a[i][j]);
int e,f;
scanf("%d%d",&e,&f);
int b[e][f];
for(i=0; i
for(j=0; j
scanf("%d",&b[i][j]);
if(e==0&&f==0)
{
return 0;
}
else if(m==e&&n==f)
{
for(i=0;i
{
for(j=0;j
{
if(j!=0)
putchar(' ');
printf("%d",a[i][j]+b[i][j]); }
putchar('\n');
}
putchar('\n');
}
else
{
printf("Not satisfied the definition of matrix addition!\n\n");
}
scanf("%d%d",&m,&n);
}while(m!=0&&n!=0);
return 0;
}