【发布时间】:2020-05-30 23:05:32
【问题描述】:
在这个程序中,我应该找出矩阵有多少个显性数字。占主导地位的数字是比右下方的数字更大的数字(请忍受我的英语)。
我输入了这个:
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;
}
【问题讨论】:
标签: c arrays function multidimensional-array