已知数据文件IN76.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组a中,请编制一函数jsVal(),其功能是:把个位数字和千位数字重新组合成一个新的十位数ab(新十位数的十位数字是原4位数的个位数字,新十位数的个位数字是原4位数的千位数字),以及把百位数和十位数组成另一个新的十位数cd(新十位数的十位数字是原4位数的百位数字,新十位数的个位数字是原4位数的十位数字),如果新组成的两个十位数必须是一个奇数,另一个为偶数且两个十位数中至少有一个数能被17整除,同时两个新十位数字均不为0,则将满足此条件的4位数按从大到小的顺序存入数组b中,并要计算满足上述条件的4位数的个数cnt,最后调用写函数writeDat()把结果cnt及数组b中符合条件的4位数输出到OUT76.DAT文件中。
注意:部分源程序已给出.
程序中已定义数组:a[200],b[200],已定义变量;cnt。
请勿改动主函数main()、读函数readDat()和写函数writeDat()的内容。
试题程序:
#include<stdio.h>
#define MAX 200
int a[MAX],b[MAX],cnt=0;
void jsVal()
void readDat()
int i;
FILE *fp;
fp=fopen("IN76.DAT","r");
for(i=0;i<MAX;i++)
fscanf(fp,"%d",&a[i]);
fclose(fp);
main()
int i;
readDat();
jsVal();
printf("满足条件的数=%d\n", cnt);
for(i=0;i<cnt;i++)
printf("%d",b[i]);
printf("\n");
writeDat();
writeDat()
FILE *fp;
int i;
fp=fopen("OUT76.DAT","w");
fprintf(fp,"%d\n",cnt);
for(i=0;i<cnt;i++)
fprintf(fp, "%d\n",b[i]);
fclose(fp);
参考答案:
void isVal( )
{
int i,thou,hun,ten,data,j;
int ab,cd;
for(i=0;i<B00;i++)
{
thou=a[i]/A000; /*求四位数的千位数字*/
hun=a[i]%A000/A00; /*求四位数的百位数字*/
ten=a[i]%A00/A0; /*求四位数的十位数字*/
data=a[i]%A0; /*求四位数的个位数字*/
ab=data*A0+thou; /*把个位数和千位数组合成一个新的十位数ab*/
cd=hun*A0+ten; /*把百位数和十位数组成另一个新的十位数cd*/
if((ab%AG==0||cd%AG==0)&&((ab%B!=A &&cd%B==A)||(ab%B==A
&&cd%B!=A))&&ab!=0&& cd!=0)
{ /*如果新组成的两个十位数必须是一个奇数,另一个为偶数且两个十位数中至少有一个数能被AG整除,同时两个新十位数字均不为0*/
b[cnt]=a[i]; /*则将满足条件的数存入数组b中*/
cnt++; /*统计满足条件的数的个数*/
}
}
for(i=0;i<cnt-A;i++) /*将数组b中的数按从大到小的顺序排列*/
for(j=i+A;j<cnt;j++)
if(b[i]<b[j])
{
data=b[i];
b[i]=b[j];
b[j]=data;
}
}
解析:
本题考查的知识点如下:
(1) 将一个4位整数各位上的数转变成单独的个位数。
(2) 判断结构中多个条件的布尔运算。
(3) 循环的使用。
(4) 数据的排序。
在本题中,首先要将一个4位数的千位、百位,十位、个位拆成独立的数字。这里借助特殊运算符号“%”(取余)和“/” (整除)。将一们位敷整除1000则可得到其千位上的数字,除以1000取余再整除100则可得百位上的数字,除以100取余再整除10则可得十位上的数字,除以10驭余则得个位上的数字。若一个数除以2取余为0,则这个数是偶数,否则为奇数。两个数必须一个为奇数,另一个为偶数,这就有两种情况:ad为奇数,cd为偶数;或者ab为偶数,cd为奇数。两者满足一种即可,所以这两种情况间用“或”运算。两个数中至少有1个能被17整除,曲能被17整除与cd能被17整除两个条件满足一个即可,所以这两个条件之间用“或”运算。但这个条件与其他条件必须同时满足,所以此条件与其他条件之间用“与”运算。先将满足条件的数存入数组b中,再对数组中的数据进行排序。最后的排序采用“选择排序法”。