第1题
请编一个函数void fun(int tt[M][N],int pp[N]),tt指向一个M行N列的
二维数组,求出二维数组每列中最大元素,并依次放入pp所指的一维
数组中。二维数组中的数已在主函数中给出。请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花
括号中填入你编写的若干语句。
/**********code.c**********/
#include <stdlic.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]);
参考答案:
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;imax)max=tt[i][j];/*如果各列中的其他元
素比最大值大,则将这个更大的元素看作当前该列中最大元素*/
pp[j]=max;/*将各列的最大值依次放入pp数组中*/
}
}