已知数据文件IN.dat中存有300个四位数,并已调用读函数RData()把这些数存入数组a中,请编写函数spellVal(),其功能是:求出千位上的数加个位上的数等于百位上的数加十位上的数的个数count,再把所有满足此条件的四位数依次存入数组b中,然后对数组b的四位数按从小到大的顺序进行排序。最后调用写函数WData(),把结果输出到OUT.dat文件中。
例如,6712,6+2=7+1,则该数满足条件存入数组b中,且个数count=count+1。8129,8+9!=1+2,则该数不满足条件,不存入数组b中,count变量也不加1。
注意:部分源程序已经给出。程序中已定义数组a[300],b[300];已定义变量count。请勿改动主函数main()、读函数RData()和写函数WData()的内容。
#include <stdio.h>
int a[300], b[300], count = 0;
void spellVal()
{
}
void RData()
{ FILE *fp;
int i;
fp = fopen("IN.dat", "r");
for (i=0; i<300; i++)
fscanf(fp, "%d,", &a[i]);
fclose(fp);
}
void WData()
{ FILE *fp;
int i;
fp = fopen("OUT.dat", "w");
fprintf(fp, "%d\n", count);
for (i=0; i<count; i++)
fprintf(fp, "%d\n", b[i]);
fclose(fp);
}
main()
{ int i;
RData();
spellVal();
WData();
printf("count=%d\n", count);
for (i=0; i<count; i++)
printf("b[%d]=%d\n", i, b[i]);
}
试题答案及详解
【审题分析】分析题目可知,本题只要实现spellVal()函数的功能即可。spellVal()要实现的功能是:求出千位数上的数加个位数上的数等于百位数上的数加十位数上的数的个数count,再把所有满足此条件的四位数依次存入数组b中,然后对数组b的四位数按从小到大的顺序进行排序。因此解答本题的关键在于如何将一个四位数的每位数拆分成单个数字和对数组的排序。
【解题思路】对于每一个四位数,用这个四位数除以1000,可得到这个四位数的千位上的数字输给变量thou;这个四位数对1000求余然后再除以100,可得到这个四位数百位上的数字输给变量hun;这个四位数对100求余然后再除以10,可得到这个四位数十位上的数字输给变量ten;这个四位数对10求余可得到这个四位数个位上的数字输给变量data。
然后判断thou加data的和与hun加ten的和是否相等,如果相等,则这个四位数是满足题目条件的数字,把这个数字输给数组b,同时计数变量count加1。最后利用两重循环对数组b元素进行从小到大的排序。
【参考答案】
void spellVal()
{ int i, thou, hun, ten, data, j;
for (i=0; i<300; i++)
{ thou = a[i]/1000;
hun = a[i]%1000/100;
ten = a[i]%100/10;
data = a[i]%10;
if (thou+data == hun+ten)
{ b[count] = a[i];
count++;
}
}
for (i=0; i<count-1; i++)
for (j=i+1; j<count; j++)
if (b[i] > b[j])
{ data = b[i];
b[i] = b[j];
b[j] = data;
}
}
【易错分析】用求余运算和除法运算得到一个四位数的各个位上的数字。
【考点链接】求余运算、除法运算、数组元素的从小到大排序。
责任编辑:小草