|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
方阵对角线元素求和及计数
对输入的一个N*N的方阵,求其两条对角线上的元素之和及非零元素的数量。
输入格式:
第一行输入一个不超过20的正整数N,
在接下来的N行中,依次输入方阵的每一行的N个元素,方阵元素为绝对值不超过1000的整数,中间以空格间隔。
输出格式:
在一行中以sum = <s>, count = <c>.的格式输出方阵两对角线上的元素之和以及非零元素的数量,其中<s>和<c>分别表示元素之和、非零元素数量,输出时以实际数量替换。
提示:(1)两条对角线的交叉元素不重复计算;(2)严格按规定格式输出,不得随意增删空格、换行等字符。
输入样例1:
4
1 2 3 4
1 2 3 4
0 1 2 3
0 1 2 3
输出样例1:
sum = 16, count = 7.
输入样例2:
5
1 2 3 2 1
1 2 3 2 1
1 2 3 2 1
1 2 3 2 1
1 2 3 2 1
输出样例:
sum = 15, count = 9.
代码有问题,不完全正确,麻烦看看
- #include <stdio.h>
- #include <stdlib.h>
- //对角线规律,左上到右下规律,行列相等
- //右上到坐下,行+列==N
- int main(void)
- {
- int num[10][10];
- int a;
- scanf("%d",&a);
- int sum = 0;
- int i,j;
- int b = 0;
- for(i=0;i<a;i++)
- {
- for(j=0;j<a;j++)
- {
- scanf("%d",&num[i][j]);
- }
- }
-
- if(a%2==0)
- {
- for(i=0;i<a;i++)
- {
- for(j=0;j<a;j++)
- {
-
-
- if(i==j)
- {
- sum = sum +num[i][j];
- if(num[i][j]==0)
- {
- b+=1;
- }
- }
- if(i+j==a-1)
- {
- sum = sum +num[i][j];
- if(num[i][j]==0)
- {
- b +=1;
- }
- }
-
- }
- }
- printf("sum = %d, count = %d.\n",sum,2*a-b);
- }
-
-
- if(a%2 !=0)
- {
- for(i=0;i<a;i++)
- {
- for(j=0;j<a;j++)
- {
-
-
- if(i==j)
- {
- sum = sum +num[i][j];
- if(num[i][j]==0)
- {
- b+=1;
- }
- }
- if(i+j==a-1)
- {
- sum = sum +num[i][j];
- if(num[i][j]==0)
- {
- b +=1;
- }
- }
-
- }
- }
- printf("sum = %d, count = %d.\n",sum-num[a/2][a/2],2*a-b-1);
- }
-
- system("pause");
- return 0;
-
- }
复制代码
|
|