原题:功能:编写函数int fun(int a[N][N]),求5行5列矩阵的主、副对角线上元素之和。注意,两条对角线相交的元素只加一次。
算法一:
#include "stdio.h"
#define N 3
int fun(int a[N][N])
{
int i,j,s=0;
for(i=0;i<N;i++)
for(j=0;j<N;j++)
if(i==j||i+j==N-1)
s=s+a[i][j];
return s;
}
void main()
{
int a[N][N],i,j;
for(i=0;i<N;i++)
for(j=0;j<N;j++)
scanf("%d",&a[i][j]);
printf("sum=%d\n",fun(a));
}
算法二:
#include "stdio.h"
#define N 3
int fun(int a[N][N])
{
int i,s=0;
for(i=0;i<N;i++)
s=s+a[i][i]+a[i][N-1-i];
s=s-a[(N-1)/2][(N-1)/2]; //减去两条对角线相交的元素
return s;
}
void main()
{
int a[N][N],i,j;
for(i=0;i<N;i++)
for(j=0;j<N;j++)
scanf("%d",&a[i][j]);
printf("sum=%d\n",fun(a));
}