源程序:
#include <stdio.h>
#include <stdlib.h>
#define M 6
#define N 5
void getdata(int(*)[M]);
void lineave(int[][M],float *);
void outdata(int [N][M],float *);;
void main()
{
int r[N][M];
float ave[N];
getdata(r);
lineave(r,ave);
outdata(r,ave);
}
void getdata(int(*sp)[M])
{
int i,j,x;
for(i=0;i<N;i++)
{
j=0;
while(j<M)
{
x=rand()%41;
if(x>=10)
{
sp[i][j]=x;
j++;
}
}
}
}
void lineave(int s[][M],float *a)
{
int i,j;
float ave;
for(i=0;i<N;i++)
{
ave=0.0;
for(j=0;j<M;j++)
ave=ave+s[i][j];
a[i]=ave/M;
}
}
void outdata(int sp[N][M],float a[])
{
int i,j;
printf("output the result:
");
for(i=0;i<N;i++)
{
for(j=0;j<M;j++)
{
printf("%4d",sp[i][j]);
}
printf(": %6.2f
",a[i]);
}
putchar('
');
}
运行结果: