在这个程序中,我应该找出矩阵有多少个主导数。一个显性数是一个比右下方的数字大的数字(请负担我的英语)。

我输入了这个:

5 (9) 2  4  1 (7)  2  4///
3  5  6  2  5 (6)  1  2///
1  3  4  7  8 (8) (3) 0///
1  3  5  6  7  8   2  1///


我圈出的那些应该是占主导地位的,但是它给了我6,出了什么问题?

#include <stdio.h>
#include <stdlib.h>

#define NR 4
#define NC 8

int dominants(int a[NR][NC]);
int main(int argc, char * argv[]){
int array[NR][NC];
int ndom;
int i,j;


for(i=0;i<NR;i++){
        for(j=0;j<NC;j++){

        scanf("%d", &array[i][j]);
        }
}
printf("array entered:\n\n");
for(i=0;i<NR;i++){
        printf("\n");
        for(j=0;j<NC;j++){

        printf("%d  ", array[i][j]);
        }
}

ndom=dominants(array);

printf("amount of dominant numbers:%d", ndom);
return 0;
}
int dominants(int a[NR][NC]){
int domflag;
int i,j, l, m;
int numdom=0;
for(i=0;i<NR-1;i++){
    for(j=0;j<NC-1;j++){
        for(l=i+1;l<NR;l++){
                domflag=1;
                for(m=j+1;m<NC;m++){
                if(a[i][j]<=a[l][m]){
                    domflag=0;
                                    }
                                   }
                           }
            if(domflag==1){
                numdom++;
                          }
        }

    }
    return numdom;
}

最佳答案

domflag = 1;在循环for (l = i + 1; l < NR; l++)内,但应在循环外。

减少此类错误的一种好方法是仅在需要它们的位置定义标识符。如果删除了例程顶部的int domflag;定义并将语句domflag = 1;更改为int domflag = 1;,则编译器将在以后测试domflag == 1时给出错误,因为这不在范围内的定义。

关于c - 检查二维数组中有多少个主导数,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/60238338/

10-12 16:16