①目标
求N个正数的平均值av?
并求其中小于且最接近平均值的数p?
~
②命令行
#include<stdio.h>
#include<stdlib.h>
#define N 10
~
③定义函数
double fun(double x[ ],double* av)
{int i,j;
double *av;
s=0;
for(i=0;i<N;i )s=s x[i];
/*先求和,x[i]是把新元素依次加上的意思*/
*av=s/N;
/*再求平均值,总和除以个数*/
d=999;
/*偏移量初始值取999,>49,肯定大于任何一个元素,保证*av-x[i]<=d顺利执行。*/
for(i=0;i<N;i )if(x[i]<*av&&*av-x[i]<=d)
/*条件是x[i]小于平均值,且最接近平均值,即偏移量d趋近于0。*/
{d=*av-x[i];
/*更新偏移量d,每找到一个小于平均值的数,就将其与平均值的差,作为新的偏移量,直到最小,所以初始d=999没关系,重点是趋势。*/
j=i;}
/*因为x[i]是不断变化的,所以求出小于且最接近平均值的数,将其下表赋值给j储存固定下来。*/
return x[j];
}
~
④主函数(调用)
viod main( )
{int i;
double x[N],av,p;
for(i=0;i<N;i ){x[i]=rand()P;printf("%4.0f",x[i]);}
/*x[i]在0至49取随机数,所以偏移量d大于49即可启动条件语句。*/
printf("\n");
p=fun(x,&av);
/*p就是函数值,即小于且最接近平均值的x[j]。*/
printf("\n the average is :%f\n",av);
printf("p=%5.1f",p);
printf("\n");}
,