鱼C论坛

 找回密码
 立即注册
查看: 1327|回复: 0

二维数组对角线和

[复制链接]
发表于 2020-1-14 09:14:12 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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.
代码有问题,不完全正确,麻烦看看
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. //对角线规律,左上到右下规律,行列相等
  4. //右上到坐下,行+列==N
  5. int main(void)
  6. {
  7.     int num[10][10];

  8.     int a;
  9.     scanf("%d",&a);
  10.     int sum = 0;
  11.     int i,j;
  12.     int b = 0;

  13.     for(i=0;i<a;i++)
  14.     {
  15.         for(j=0;j<a;j++)
  16.         {
  17.             scanf("%d",&num[i][j]);
  18.         }
  19.     }
  20.    
  21.     if(a%2==0)
  22.     {
  23.         for(i=0;i<a;i++)
  24.         {
  25.             for(j=0;j<a;j++)
  26.             {
  27.                
  28.                
  29.                     if(i==j)
  30.                     {
  31.                         sum = sum +num[i][j];
  32.                         if(num[i][j]==0)
  33.                         {
  34.                             b+=1;
  35.                         }
  36.                     }
  37.                     if(i+j==a-1)
  38.                     {
  39.                         sum = sum +num[i][j];
  40.                         if(num[i][j]==0)
  41.                         {
  42.                             b +=1;
  43.                         }
  44.                     }
  45.                
  46.             }
  47.         }
  48.         printf("sum = %d, count = %d.\n",sum,2*a-b);
  49.     }
  50.    

  51.    
  52.     if(a%2 !=0)
  53.     {
  54.         for(i=0;i<a;i++)
  55.         {
  56.             for(j=0;j<a;j++)
  57.             {
  58.                
  59.                
  60.                     if(i==j)
  61.                     {
  62.                         sum = sum +num[i][j];
  63.                         if(num[i][j]==0)
  64.                         {
  65.                             b+=1;
  66.                         }
  67.                     }
  68.                     if(i+j==a-1)
  69.                     {
  70.                         sum = sum +num[i][j];
  71.                         if(num[i][j]==0)
  72.                         {
  73.                             b +=1;
  74.                         }
  75.                     }
  76.                
  77.             }
  78.         }
  79.         printf("sum = %d, count = %d.\n",sum-num[a/2][a/2],2*a-b-1);
  80.     }
  81.    

  82.     system("pause");

  83.     return 0;


  84.    
  85. }
复制代码

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-16 09:14

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表