【问题描述】输入一个n*m的矩阵,计算每行之和,作为该行的最后一个元素,计算每列之和,作为该列的最后一个元素,输出新的矩阵。
【输入形式】第一行输入n和m,接下来的n行均包含m个整数
【输出形式】输出(n+1)*(m+1)的矩阵,共有n+1行,每行包含m+1个整数。矩阵的最后一个元素为所有原始数据之和。
【样例输入】2 31 2 53 6 9
【样例输出】1 2 5 83 6 9 184 8 14 26
#include <iostream>
using namespace std;
int main()
{
int n,m,i,j;
cin>>n>>m;
int a[n+1][m+1];
a[n][m]=0;
for(i=0;i<n;i++)
{
a[i][m]=0;
for(j=0;j<m;j++)
{
cin>>a[i][j];
a[i][m]+=a[i][j];
}
}
for(j=0;j<m;j++)
{
a[n][j]=0;
for(i=0;i<n;i++)
a[n][j]+=a[i][j];
}
for(i=0;i<m;i++)
a[n][m]+=a[n][i];
for(i=0;i<=n;i++)
{
for(j=0;j<=m;j++)
cout<<a[i][j]<<' ';
cout<<endl;
}
return 0;
}