2009ProblemsB

本文介绍了一个程序设计问题,即对于一个m行n列的方阵,如何计算每一行、每一列及主对角线元素之和,并按从大到小的顺序输出这些和。文章提供了完整的C++代码实现,包括输入矩阵、计算各方向元素和以及排序输出的过程。

请写一个程序,对于m行n列的(1<m<10)的方阵,求其每一行,每一列及主对角线元素之和,最后按照从大到小的顺序一次输出。

输入说明:共一组数据,输入的一行为一个正整数,表示m,接下来的m行,每行m个整数表示方阵元素。

输出说明:从大到小排列的一行整数,每个整数后跟一个空格,最后换行。

输入样本:
4
15 8 -2 6
31 24 18 71
-3 -9 27 13
17 21 38 69
输出样本:
159 145 144 135 81 60 44 32 28 27

#include "iostream"
#include "algorithm"
#include "cstring"
using namespace std;

int main(){
	int m;
	cin>>m;
	int str[m][m];
	for(int i=0;i<m;i++)
		for(int j=0;j<m;j++){
			cin>>str[i][j];
		}//输入矩阵
	int t = 2*m+2;
	int a[t];
	memset(a,0,sizeof(a));
	for(int i=0;i<m;i++){
		for(int j=0;j<m;j++){
			a[i] += str[i][j]; 
			
		}

		for(int r=0;r<m;r++){
			a[i+m] += str[r][i];
	
		}
		
	}
	for(int i=0;i<m;i++){
		a[2*m]+=str[i][i];
		a[2*m+1]+=str[i][m-1-i];
	} 

	sort(a,a+2*m+2);
	
	for(int i=2*m+1;i>=0;i--){
		cout<<a[i];
		if(i>0) 
			cout<<"_"; 
		else if(i==0)
			cout<<endl;
	}
	
}
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值