编程题

请编一个函数 void fun(int tt[M][N], int pp[N]), tt 指向一个 M 行 N 列的二维数组, 求出二维数组每列中最大元素, 并依次放入 pp 所指的一维数组中。 二维数组中的数已在主函数中给出。
注意:
请勿改动主函数 main 和其他函数中的任何内容, 仅在函数 fun 的花括号中填入你编写的若干语句。
【试题源程序】

#include <stdlib.h>
#include <conio.h>
#include <stdio.h>
#define M 3
#define N 4
void fun(int tt[M][N],int pp[N])
{

}
void main()
{
   int t[M][N]={{68,32,54,12},{14,24,88,58},{42,22,44,56}};
   int p[N],i,j,k;
   system("CLS");
   printf("The riginal data is:\n");
   for(i=0;i<M;i++)
   {
      for(j=0;j<N;j++)printf("%6d",t[i][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,j,max;
   if(tt==NULL||pp==NULL)return;
   for(j=0;j<N;j++)
   {
      max=tt[0][j];/*假设各列中的第一个元素最大*/
      for(i=1;i<M;i++)if(tt[i][j]>max)max=tt[i][j];/*如果各列中的其他元素比最大值大, 则将这个更大的元素看作当前该列中最大元素*/
      pp[j]=max;/*将各列的最大值依次放入 pp 数组中*/
   }
}

【答案解析】

根据题意可知, fun 函数实现的功能是对给定二维数组中每列的元素进行比较, 得出最大值后依次输出至一维数组中。 设计思路如下: 定义一个最大值变量 max, 首先将每列的第一个元素设为最大值, 然后将最大值 max 与第二个元素比较, 较大值赋给 max; 以此类推, 将 max 依次与第三, „, M 个元素比较, 得出该列最大值, 并进行输出。