C中第二个平分线右侧的元素总和

时间:2012-11-19 11:47:27

标签: c matrix

我正在尝试在C中创建一个函数,用于计算二维方阵右侧元素的总和。 (只有以下评论中的1个元素) 到目前为止,我已经得到了这个,但它是不正确的,因为它计算整个矩阵的元素总和:

  #define N 5
  int a[N][N] ={{0,0,0,0,1},
                {0,0,0,1,1},
                {0,0,1,1,1},
                {0,1,1,1,1},
                {1,1,1,1,1}};


 /*
    {0,0,0,0,1},
    {0,0,0,1,1},
    {0,0,1,1,1},
    {0,1,1,1,1},
    {1,1,1,1,1},
    sum =
                                            a[0][4] + 
                                  a[1][3] + a[1][4] + 
                        a[2][2] + a[2][3] + a[2][4] + 
              a[3][1] + a[3][2] + a[3][3] + a[3][4] +
    a[4][0] + a[4][1] + a[4][2] + a[4][3] + a[4][4]
    */

    int sumSndBisRight(int a[N][N]) {
          int i, j, sum = 0, k = N - 1;
          for( i = 0;i < N;i++) 
              for( j = (N - 1);j >= 0;j--)          
                           sum += a[i][j];          
          return sum;  
    }
    void main() {
    int sum;
    sum = sumSndBisRight(a);
    printf("%d", sum);
    }

提前感谢您的帮助。

1 个答案:

答案 0 :(得分:1)

更改

for( j = (N - 1);j >= 0;j--)

for( j = N-1-i; j < N; j++)