给定程序MOD11.C中,函数fun的功能是求矩阵(二维数组)a[N][N]中每行的最小值,结果存放到数组b中。 假如:若 则结果应为 1,5,9,13, 请改正函数fun中指定部位的错误,使它能得出正确的结果。 注意:不要改动main函

admin2017-09-23  23

问题 给定程序MOD11.C中,函数fun的功能是求矩阵(二维数组)a[N][N]中每行的最小值,结果存放到数组b中。
假如:若

则结果应为
1,5,9,13,
    请改正函数fun中指定部位的错误,使它能得出正确的结果。
    注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。
    试题程序:
#inclucle < stdio.h >
#define N 4
void fun(int a[][N],int b[])
{int i,j;
  for(i=0;i < N;i++)
  {
/*********found*********/
  b=a[0][0];
/*********found*********/
    for(j=1;j < N一1;j++)
/*********found*********/
    if(b < a[j])
    b=a[j];
    }
}
main()
(int a[N][N]={{1,4,3,2),{8,6,
5,7),{11,1 0,12,9),{13,1 6,1 4,
15)),b[N];
int i;
fun(a,b);
for(i=0 j i < N;i++)
  printf("%d,",b);
printf("\n");
}

选项

答案(1)b[i]=a[i][0]; (2)for(j=1;j<N;j++) (3)if(b[i]>a[i][j])

解析 数组b存放每行的最小值,针对二维数组使用二层循环,在第一层循环的开始将每行的第1个数赋给数组b相应的元素,在第二层循环中,数组b中的元素依次与本行中的每个元素进行比较,找到一行中的最小值存入数组b。
(1)b存放二级数组a每一行中第1个元素值,表示为a[0]。
(2)每行元素的第1个值要和这一行中的每个元素进行比较,条件j<N可使a[j]取到最后元素,而条件j<N一l使a[j]最终取得倒数第2个元素。
(3)因为是找最小值,所以当b大于其后的数值时说明它不是最小,要把比较中较大的值赋给它。
转载请注明原文地址:https://jikaoti.com/ti/PTa0FFFM
0

最新回复(0)