fclose (fp);
参考答案:void CalValue()
{
int i, thou, hun, ten, data;
int ab;
long sum=0;
for (i=0; i〈HAXNUM; i++)
{
if(MX[i]>0)
{
totNum++; /*统计正整数的个数*/
thou=xx[i]/A000; /*求正整数的千位数*/
hun=xx[i]%A000/A00; /*求正整数的百位数*/
ten=xx[i]%A00/A0; /*求正整数的十位数*/
data=xx[i]%A0; /*求正整数的个位数*/
ab=thou+hun+ten+data;
if (ab%B==0) /*如果各位数字之和是偶数*/
{totCnt++;sum=sum+xx[i];} /*计算满足条件的数的个数totCnt和这些数的总和sum*/
}
}
totPjz=sum/totCnt; /*求这些数的算术平均值totPjz*/
}
解析: 本题的解题思路是首先利用一个for循环来依次从数组中取得的数,由于题目要求求数组中正整数的个数,因此,对于为零的整数,不做任何处理,接着去取下一个数。只要某个数大于零,则该数一定是正整数,这时就给变量totNum(正整数的个数)累加1,用语句“thou=xx[i]/1000;hun=xx[i]%1000/100; ten=xx[i]%100/10;data=xx[i]%10;”可以实现取得当前被处理数的千位、百位、十位,以及个位上的数字值,之后判断求得的各个位上的数字值之和是否是偶数。若上述条件成立,则给变量totCnt的值加1,同时把当前符合条件的数累加到变量sum中去,最终利用totPjz来求得满足所给条件的所有数的平均值。