В этой программе я должен найти, сколько доминантных чисел имеет матрица. Доминирующее число - это число, которое больше, чем то, что находится ниже справа впереди (имейте в виду мой engli sh, пожалуйста).
я ввел это:
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;
}