请编一个函数void fun( int tt[M][N], int pp[N], tt指向一个M行N列的二维数组,求出二维数组每列中最大元素,并依次放入pp所指的一维数组中。二维数组中的数已在主函数中给出。 注意:部分源程序给出如下。 请勿改

admin2010-11-26  37

问题 请编一个函数void fun( int tt[M][N], int  pp[N], tt指向一个M行N列的二维数组,求出二维数组每列中最大元素,并依次放入pp所指的一维数组中。二维数组中的数已在主函数中给出。
   注意:部分源程序给出如下。
   请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。
   试题程序:
   #include  <conio.h>
   #include  <stdio.h>
   #define    M 3
   #define    N 4
   void fun(int tt[M][N],int pp[N])
   {
   }
   main()
   {
int t[M] [N]={{68,32,54,12},{14,24,88,
58},{42,  22,  44,  56}};
   int p[N],i,j,k;
   clrscr();
   printf("The riginal data is:\n");
   for(i=0;i<M;i++)
     {
   for(j=0;j<N;j++)
       printf("%6d",t[j]);
     printf("\n");
   }
   fun(t,p);
   printf("\nThe result is:\n");
   for(k=0;k<N;k++)
     printf("%4d",p[k]);
   printf("\n");
}

选项

答案void fun(int tt[M][N],int pp[N]) { int i,i,max; for(j=0;j<N;j++) { max=tt[0][j]; /*假设各列中的第一个元素最大*/ for(i=0;i<M;i++) if(tt[i][j]>max) /*如果各列中的其他元素比最大值大,则将这个更大的元素看作当前该列中最大元素*/ max=tt[i][j]; pp[j]=max; /*将各列的最大值依次放入pp数组中*/ } }

解析 本题中函数的功能是求出二维数组中每列的最大元素。首先,假设各列中的第一个元素最大,然后利用行标值的移动来依次取得各列中其他元素的值,并与假设的最大值进行比较,如果遇到更大的,则把这个更大的元素看做当前该列中最大的元素,继续与该列中其他元素比较。
转载请注明原文地址:https://kaotiyun.com/show/2PID777K
0

相关试题推荐
最新回复(0)