1、国家三级(数据库技术)机试模拟试卷 60及答案与解析 一、程序设计题 1 已知数据文件 IN60.DAT中存有 200个 4位数,并已调用读函数 readDat()把这些数存入数组 a中,请编制一函数 JsVal(),其功能是:把千位数字和十位数字重新组合成一个新的十位数 ab(新十位数的十位数字是原 4位数的千位数字,新十位数的个位数字是原 4位数的十位数字 ),以及把个位数和百位数组成另一个新的十位数 cd(新十位数的十位数字是原 4位数的个位数字,新十位数的个位数字是原 4位数的百位数字 ),如果新组成的两个十位数 ab cd, ab必须是奇数且不能被 5整除, cd必须是偶数,同时两个
2、新十位数字均不为零,则将满足此条件的 4位数按从大到小的顺序存入数组 b中,并要计算满足上述条件的 4位数的个数 cnt,最后调用写函数 writeDat()把结果 cnt及数组 b中符合条件的 4位数输出到 OUT60.DAT文件中。 注意:部分源程序已给出。 程序中已定义数组: a200, b200,己定义变量: cnt。 请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。 试题程序; #include stdio.h #define MAX 200 int aMAX,bMAX ,cnt=0; void jsVal( ) void readDat
3、 () int i; FILE *fp; fp= fopen ( “IN60. DAT“, “r“ ); for (i=0 ; i MAX; i+) fscanf(fp,“%d“, fclose(fp); main() int i; readDat(); jsVal(); printf ( “满足条件的数 =%dn“, cnt); for(i=0;i cnt;i+) printf(“%dn“,bi); printf(“n“); writeDat ( ); writeDat ( ) FILE *fp; int i; fp=fopen(“OUT60.DAT“,“w“); fprintf(fp,“%
4、dn“,cnt); for(i=0;i cnt;i+) fprintf(fp,“%dn“,bi); fclose(fp); 国家三级(数据库技术)机试模拟试卷 60答案与解析 一、程序设计题 1 【正确答案】 void jsVal( ) int i, thou, hun, ten, data, j; int ab, cd; for(i=0; i 200; i+) thou=ai/1000; /*求四位数的千位数字 */ hun-ai%1000/100; /*求四位数的百位数字 */ ten=ai%100/10; /*求四位数的十位数字 */ data=ai%10; /*求四位数的个位数字 */
5、 ab=10*thou+ten; /*把千位数和十位数重新组合成一个新的十位数 ab*/ cd=10*data+hun; /*把个位数和百位数组成另一个新的十位数 cd*/ if(ab-cd 0)&(ab%2=1)&(ab%5!=0)&(cd%2=0)&ab!=0&cd!=0) /*如果 ab cd, ab是奇数且不能被 5整除, cd是偶数,同时两个数字均不为零 */ bcnt=ai; /*将满足条件的数存入数组 b中 */ cnt+; /*统计满足条件的数的个数 */ for(i=0; i cnt-1; i+) /*将数组 b中的 4位数按从大到小的顺序 */ for(j=i+1; j c
6、nt; j+) if(bi bj) data=bi; bi=bj; bj=data; 【试题解析】 本题考查的知识点如下: (1)将 4位数各位上的数拆分为独立的数字。 (2)循环结构的使用。 (3)判断结构中多个条件的布尔运算。 在本题中,首先要将 4位数各位上的数字拆分为独立的数字。这要借助运算符“%”( 取余 )与 “/”(整除 )。将一个 4位数整除 1000则可得到其千位上的数字,除以1000取余再整除 100则可得百位上的数字,除以 100取余再整除 10则可得十位上的数字,除以 10取余则得个位上的数字。求得各位上的数字后,就可以重新组合进行比较。各条件必须同时满足,所以用 “”运算。题中要求将符合条件的数按从大到小的顺序存入数组 b,可以先将符合条件的数存入数组 b,再对数组 b进行排序。排序使用 “选择排序法 ”。