加题目更好理解(嘿嘿)
输入
输入第一行是m和n,然后是一个m行n列的矩阵。
输出
输出一个整数,表示矩阵所有边界元素的和。
样例输入
3 4
1 2 6 4
5 6 7 8
9 5 4 6
样例输出
50
#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
int main(){
int n,m;
cin>>n>>m;
vector<vector<int>> a(max(n,m));//创建的是n*n矩阵,故要设为最大列或者行数
long long sum=0;
for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
int x;
cin>>x;
a[i].push_back(x);//插入该列末尾
}
}
for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
if(i==0) sum+=a[i][j];//对二维数组中元素的引用
else if(i>0&&i<n-1 &&(j==0 || j==m-1))sum+=a[i][j];
else if(i==n-1) sum+=a[i][j];
}
}
cout<<sum;
return 0;
}