1、三级数据库技术机试-244 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:5,分数:100.00)1.已知在 IN.DAT文件中存有若干个(200)四位数字的正整数,函数 ReadDat()读取这若干个正整数并存入数组 xx中。请编写函数 CalValue(),其功能是:(1)求出这个文件中共有多少个正整数 totNum;(2)求这些数右移 1位后,产生的新数是偶数的数的个数 totCnt,以及满足此条件的这些数(右移前的值)的算术平均值 totPjz,最后调用函数 writeDat()把所求的结果输出到 OUT.DAT文件中。注意:部分程序已经给出。请勿改动主函数
2、 main()、读函数 ReadDat()和写函数 witeDat()的内容。#includestdio.h#includeconio.h#define MAXNUM 200int xxMAXNUM;int totNum=0;int totCnt=0;double totPjz=0.0;int ReadDat(void);void writeDat(void);void CalValue(void)void main()int i;for(i=0;iMAXNUM;i+)xxi=0;if(ReadDat()printf(“数据文件 IN.DAT不能打开!/007/n“);return;CalVa
3、lue();printf(“IN.DAT文件中的正整数个数=%d 个/n“,totNum);printf(“符合条件的正整数个数=%d 个/n“,totCnt);printf(“平均值=%.2f/n“,totPjz);writeDat();int ReadDat(void)FILE *fp;int i=0;if(fp=fopen(“IN.DAT“,“r“)=NULL)return 1;while(!feof(fp)fscanf(fp,“%d,“,xxi+);fclose(fp);return 0;void writeDat(void)FILE *fp;fp=fopen(“OUT.DAT“,“w
4、“);fprintf(fp, “%d/n%d/n%6.2f/n“,totNum,totCnt,totPjz);fclose(fp);(分数:20.00)_2.已知数据文件 in.dat中存有 300个四位数,并已调用读函数 ReadDat()把这些数存入数组 a中。请编写函数 jsValue(),其功能是:求出千位数上的数减百位数上的数减十位数上的数减个位数上的数大于零的个数 cnt,再把所有满足此条件的四位数依次存入数组 b中,然后对数组 b的四位数按从小到大的顺序进行排序,最后调用写函数 writeDat(),把结果输出到 out.dat文件中。例如:9123,9-1-2-30,则该数满足
5、条件存入数组 b中,且个数 cnt=cnt+1。9812,9-8-1-20,则该数不满足条件忽略。注意:部分程序已经给出。程序中已定义数组:a300,b300;已定义变量:cnt。请勿改动主函数 main()、读函数 ReadDat()和写函数 witeDat()的内容。#includestdio.hint a300,b300,cnt=0;void jsValue()void ReadDat()FILE *fp;int i;fp=fopen(“in.dat“,“r“);for(i=0;i300;i+)fscanf(fp,“%d,“,ai);fclose(fp);void writeDat()F
6、ILE *fp;int i;fp=fopen(“out.dat“,“w“);fprintf(fp,“%d/n“,cnt);for(i=0;icnt;i+)fprintf(fp,“%d/n“,bi);fclose(fp);main()int i;ReadDat();jsValue();writeDat();printf(“cnt=%d/n“,cnt);for(i=0;icnt;i+)printf(“b%d=%d/n“,i,bi);(分数:20.00)_3.已知数据文件 IN.DAT中存有 200个四位数,并已调用读函数 readDat()把这些数存入数组 a中。请编写函数 jsVal(),其功能
7、是:把千位数字和十位数字重新组成一个新的十位数 ab(新十位数的十位数字是原四位数的千位数字,新十位数的个位数字是原四位数的十位数字),以及把个位数字和百位数字组成另一个新的十位数 cd(新十位数的十位数字是原四位数的个位数字,新十位数的个位数字是原四位数的百位数字),如果新组成的两个十位数 ab-cd0 且 ab-cd10 且两个数均是奇数,同时两个新数的十位数字均不为零,则将满足此条件的四位数按从大到小的顺序存入数组 b中,并计算满足上述条件的四位数的个数cnt。最后 main()函数调用写函数 writeDat(),把结果 cnt以及数组 b中符合条件的四位数输出到OUT.DAT文件中。
8、注意:部分程序已经给出。程序中已定义数组:a200,b200;已定义变量:cnt。请勿改动数据文件 IN.DAT中的任何数据及主函数 main()、读函数 readDat()和写函数 writeDat()的内容。#includestdio.h#define MAX 200int aMAX,bMAX,cnt=0;void jsVal()void readDat()int i;FILE *fp;fp=fopen(“IN.DAT“,“r“);for(i=0;iMAX;i+)fscanf(fp,“%d,“,ai);fclose(fp);void writeDat()FILE*fp;int i;fp=f
9、open(“OUT.DAT“,“w“);fprintf(fp,“%d/n“,cnt);for(i=0;icnt;i+)fprintf(fp,“%d/n“,bi);fclose(fp);void main()int i;readDat();jsVal();printf(“满足条件的数=%d/n“,cnt);for(i=0;icnt;i+)printf(“%d“,bi);printf(“/n“);writeDat();(分数:20.00)_4.已知数据文件 in.dat中存有 200个四位数,并已调用读函数 readDat()把这些数存入数组 a中。请编写函数 jsVal(),其功能是:把干位数字
10、和十位数字重新组成一个新的十位数 ab(新十位数的十位数字是原四位数的千位数字,新十位数的个位数字是原四位数的十位数字),以及把个位数字和百位数字组成另一个新的十位数 cd(新十位数的十位数字是原四位数的个位数字,新十位数的个位数字是原四位数的百位数字),如果新组成的两个十位数 ab-cd10 且 ab-cd20 且两个数均是偶数,同时两个新数的十位数字均不为零,则将满足此条件的四位数按从大到小的顺序存入数组 b中,并计算满足上述条件的四位数的个数 cnt。最后 main()函数调用写函数 writeDat(),把结果 cnt以及数组 b中符合条件的四位数输出到 out.dat文件中。注意:部
11、分程序已经给出。程序中已定义数组:a200,b200;已定义变量:cnt。请勿改动数据文件 in.dat中的任何数据及主函数 main()、读函数 readDat()和写函数 writeDat()的内容。#includestdio.h#define MAX 200int aMAX,bMAX,cnt=0;void jsVal()void readDat()int i;FILE *fp;fp=fopen(“in.dat“,“r“);for(i=0; iMAX;i+)fscanf(fp,“%d,“,ai);fclose(fp);void writeDat()FILE*fp;int i;fp=fope
12、n(“out.dat“,“w“);fprintf(fp,“%d/n“,cnt);for(i=0;icnt;i+)fprintf(fp,“%d/n“,bi);fclose(fp);void main()int i;readDat();jsVal();printf(“满足条件的数=%d/n“,cnt);for(i=0; icnt;i+)printf(“%d“,bi);printf(“/n“);writeDat();(分数:20.00)_5.已知数据文件 IN.DAT中存有 200个四位数,并已调用读函数 readDat()把这些数存入数组 a中。请编写函数 jsVal(),其功能是:依次从数组 a
13、中取出一个四位数,如果该四位数连续小于该四位数以后的五个数且该数是偶数(该四位数以后不满五个数,则不统计),则统计出满足此条件的个数 cnt并把这些四位数按从小到大的顺序存入数组 b中,最后调用写函数 writeDat(),把结果 cnt以及数组 b中符合条件的四位数输出到 OUT.DAT文件中。注意:部分程序已经给出。程序中已定义数组:a200,b200;已定义变量:cnt。请勿改动数据文件 IN.DAT中的任何数据及主函数 main()、读函数 readDat()和写函数 writeDat()的内容。#includestdio.h#define MAX 200int aMAX,bMAX,c
14、nt=0;void jsVal()void readDat()int i;FILE *fp;fp=fopen(“IN.DAT“,“r“);for(i=0;iMAX; i+)fscanf(fp,“%d,“,ai);fclose(fp);void writeDat()FILE *fp;int i;fp=fopen(“OUT.DAT“,“w“);fprintf(fp,“%d/n“,cnt);for(i=0;icnt;i+)fprintf(fp,“%d/n“,bi);fclose(fp);void main()int i;readDat();jsVal();printf(“满足条件的数=%d/n“,c
15、nt);for(i=0; icnt;i+)printf(“%d“,bi);printf(“/n“);writeDat();(分数:20.00)_三级数据库技术机试-244 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:5,分数:100.00)1.已知在 IN.DAT文件中存有若干个(200)四位数字的正整数,函数 ReadDat()读取这若干个正整数并存入数组 xx中。请编写函数 CalValue(),其功能是:(1)求出这个文件中共有多少个正整数 totNum;(2)求这些数右移 1位后,产生的新数是偶数的数的个数 totCnt,以及满足此条件的这些数(右移前的值)
16、的算术平均值 totPjz,最后调用函数 writeDat()把所求的结果输出到 OUT.DAT文件中。注意:部分程序已经给出。请勿改动主函数 main()、读函数 ReadDat()和写函数 witeDat()的内容。#includestdio.h#includeconio.h#define MAXNUM 200int xxMAXNUM;int totNum=0;int totCnt=0;double totPjz=0.0;int ReadDat(void);void writeDat(void);void CalValue(void)void main()int i;for(i=0;iMA
17、XNUM;i+)xxi=0;if(ReadDat()printf(“数据文件 IN.DAT不能打开!/007/n“);return;CalValue();printf(“IN.DAT文件中的正整数个数=%d 个/n“,totNum);printf(“符合条件的正整数个数=%d 个/n“,totCnt);printf(“平均值=%.2f/n“,totPjz);writeDat();int ReadDat(void)FILE *fp;int i=0;if(fp=fopen(“IN.DAT“,“r“)=NULL)return 1;while(!feof(fp)fscanf(fp,“%d,“,xxi+
18、);fclose(fp);return 0;void writeDat(void)FILE *fp;fp=fopen(“OUT.DAT“,“w“);fprintf(fp, “%d/n%d/n%6.2f/n“,totNum,totCnt,totPjz);fclose(fp);(分数:20.00)_正确答案:(void CalValue(void)int i,data;for(i=0;iMAXNUM;i+) /*循环以遍历数组 xx的所有元素*/if(!xxi)break; /*若当前元素为 0说明数组到此结束,跳出循环*/if(xxi0)totNum+; /*若当前元素大于 0,让计数值 tot
19、Num增 1*/data=xxi1; /*将当前元素右移一位存入 data*/if(data%2=0) /*如果 data是偶数*/totCnt+; /*让计数值 totCnt增 1*/totPjz+=xxi; /*将该数累加至 totPjz中*/totPjz/=totCnt; /*将 totPjz中的累加值除以累加个数得平均值*/)解析:2.已知数据文件 in.dat中存有 300个四位数,并已调用读函数 ReadDat()把这些数存入数组 a中。请编写函数 jsValue(),其功能是:求出千位数上的数减百位数上的数减十位数上的数减个位数上的数大于零的个数 cnt,再把所有满足此条件的四位
20、数依次存入数组 b中,然后对数组 b的四位数按从小到大的顺序进行排序,最后调用写函数 writeDat(),把结果输出到 out.dat文件中。例如:9123,9-1-2-30,则该数满足条件存入数组 b中,且个数 cnt=cnt+1。9812,9-8-1-20,则该数不满足条件忽略。注意:部分程序已经给出。程序中已定义数组:a300,b300;已定义变量:cnt。请勿改动主函数 main()、读函数 ReadDat()和写函数 witeDat()的内容。#includestdio.hint a300,b300,cnt=0;void jsValue()void ReadDat()FILE *f
21、p;int i;fp=fopen(“in.dat“,“r“);for(i=0;i300;i+)fscanf(fp,“%d,“,ai);fclose(fp);void writeDat()FILE *fp;int i;fp=fopen(“out.dat“,“w“);fprintf(fp,“%d/n“,cnt);for(i=0;icnt;i+)fprintf(fp,“%d/n“,bi);fclose(fp);main()int i;ReadDat();jsValue();writeDat();printf(“cnt=%d/n“,cnt);for(i=0;icnt;i+)printf(“b%d=%d
22、/n“,i,bi);(分数:20.00)_正确答案:(void jsValue()int i,thou,hun,ten,data,j;for(i=0;i(300;i+) /*循环以遍历数组 a中的所有 300个四位数*/thou=ai/1000; /*取当前数的千位数字*/hun=ai%1000/100; /*取当前数的百位数字*/ten=ai%100/10; /*取当前数的十位数字*/data=ai%10; /*取当前数的个位数字*/if(thou-hun-ten-data0) /*若干位减百位减十位减个位大于 0的话*/bcnt=ai; /*将此数存入数组 b*/cnt+; /*让计数值
23、cnt增 1*/*用选择排序对数组 b的前 cnt个数进行排序*/for(i=0;icnt-1;i+)for(j=i+l;jcnt;j+)if(bibj) /*若前面的数大于后面的,则交换两者(即升序排列)*/data=bi;bi=bj;bj=data;)解析:3.已知数据文件 IN.DAT中存有 200个四位数,并已调用读函数 readDat()把这些数存入数组 a中。请编写函数 jsVal(),其功能是:把千位数字和十位数字重新组成一个新的十位数 ab(新十位数的十位数字是原四位数的千位数字,新十位数的个位数字是原四位数的十位数字),以及把个位数字和百位数字组成另一个新的十位数 cd(新十
24、位数的十位数字是原四位数的个位数字,新十位数的个位数字是原四位数的百位数字),如果新组成的两个十位数 ab-cd0 且 ab-cd10 且两个数均是奇数,同时两个新数的十位数字均不为零,则将满足此条件的四位数按从大到小的顺序存入数组 b中,并计算满足上述条件的四位数的个数cnt。最后 main()函数调用写函数 writeDat(),把结果 cnt以及数组 b中符合条件的四位数输出到OUT.DAT文件中。注意:部分程序已经给出。程序中已定义数组:a200,b200;已定义变量:cnt。请勿改动数据文件 IN.DAT中的任何数据及主函数 main()、读函数 readDat()和写函数 writ
25、eDat()的内容。#includestdio.h#define MAX 200int aMAX,bMAX,cnt=0;void jsVal()void readDat()int i;FILE *fp;fp=fopen(“IN.DAT“,“r“);for(i=0;iMAX;i+)fscanf(fp,“%d,“,ai);fclose(fp);void writeDat()FILE*fp;int i;fp=fopen(“OUT.DAT“,“w“);fprintf(fp,“%d/n“,cnt);for(i=0;icnt;i+)fprintf(fp,“%d/n“,bi);fclose(fp);void
26、 main()int i;readDat();jsVal();printf(“满足条件的数=%d/n“,cnt);for(i=0;icnt;i+)printf(“%d“,bi);printf(“/n“);writeDat();(分数:20.00)_正确答案:(void jsVal()int i,thou,hun,ten,data,j;int ab.cd;for(i=0;i200;i+) /*循环以遍历数组 a中的所有 200个四位数*/thou=ai/1000; /*取当前数的千位数字*/hun=ai%1000/100; /*取当前数的百位数字*/ten=ai%100/i0; /*取当前数的十
27、位数字*/data=ai%10; /*取当前数的个位数字*/if(thou=0|data=O)/*若干位或个位为 0*/continue; /*则组成的新数至少有一个十位为 0,不符合题意继续循环*/ab=10*thou+ten; /*把千位数字和十位数字重新组成一个新的十位数*/cd=10*data+hun; /*把个位数字和百位数字重新组成一个新的十位数*/if(ab-cd)=0(ab-cd)=10ab%2=1cd%2=1) /*如果新组成的两个十位数 ab-cd0 且 ab-cd10 且两个数均是奇数*/bcnt=ai; /*将此数存入数组 b*/cnt+; /*让计数值 cnt增 1*
28、/*用选择排序对数组 b的前 cnt个数进行排序*/for(i=0;icnt-1;i+)for(j=i+1;jcnt;j+)if(bibj) /*若前面的数小于后面的,则交换两者(即降序排列)*/data=bi;bi=bj;bj=data;)解析:4.已知数据文件 in.dat中存有 200个四位数,并已调用读函数 readDat()把这些数存入数组 a中。请编写函数 jsVal(),其功能是:把干位数字和十位数字重新组成一个新的十位数 ab(新十位数的十位数字是原四位数的千位数字,新十位数的个位数字是原四位数的十位数字),以及把个位数字和百位数字组成另一个新的十位数 cd(新十位数的十位数字
29、是原四位数的个位数字,新十位数的个位数字是原四位数的百位数字),如果新组成的两个十位数 ab-cd10 且 ab-cd20 且两个数均是偶数,同时两个新数的十位数字均不为零,则将满足此条件的四位数按从大到小的顺序存入数组 b中,并计算满足上述条件的四位数的个数 cnt。最后 main()函数调用写函数 writeDat(),把结果 cnt以及数组 b中符合条件的四位数输出到 out.dat文件中。注意:部分程序已经给出。程序中已定义数组:a200,b200;已定义变量:cnt。请勿改动数据文件 in.dat中的任何数据及主函数 main()、读函数 readDat()和写函数 writeDat
30、()的内容。#includestdio.h#define MAX 200int aMAX,bMAX,cnt=0;void jsVal()void readDat()int i;FILE *fp;fp=fopen(“in.dat“,“r“);for(i=0; iMAX;i+)fscanf(fp,“%d,“,ai);fclose(fp);void writeDat()FILE*fp;int i;fp=fopen(“out.dat“,“w“);fprintf(fp,“%d/n“,cnt);for(i=0;icnt;i+)fprintf(fp,“%d/n“,bi);fclose(fp);void ma
31、in()int i;readDat();jsVal();printf(“满足条件的数=%d/n“,cnt);for(i=0; icnt;i+)printf(“%d“,bi);printf(“/n“);writeDat();(分数:20.00)_正确答案:(void jsVal()int i,thou,hun,ten,data,j;int ab,cd;for(i=0;i200;i+) /*循环以遍历数组 a中的所有 200个四位数*/thou=ai/1000; /*取当前数的千位数字*/hun=ai%1000/100; /*取当前数的百位数字*/ten=ai%100/10; /*取当前数的十位数
32、字*/data=ai%10; /*取当前数的个位数字*/if(thou=0 |data=0)/*若干位或个位为 0*/continue; /*则组成的新数至少有一个十位为 0,不符合题意继续循环*/ab=10*thou+ten; /*把千位数字和十位数字重新组成一个新的十位数*/cd=10*data+hun; /*把个位数字和百位数字重新组成一个新的十位数*/if(ab cd)=10(ab-cd)=20ab%2=0cd%2=0) /*如果新组成的两个十位数 ab-cd10 且 ab-cd20 且两个数均是偶数*/bcnt=ai; /*将此数存入数组 b*/cnt+; /*让计数值 cnt增 1
33、*/*用选择排序对数组 b的前 cnt个数进行排序*/for(i=0;icnt-1;i+)for(j=i+1;jcnt;j+)if(bibj) /*若前面的数小于后面的,则交换两者(即降序排列)*/data=bi;bi=bj;bj=data;)解析:5.已知数据文件 IN.DAT中存有 200个四位数,并已调用读函数 readDat()把这些数存入数组 a中。请编写函数 jsVal(),其功能是:依次从数组 a中取出一个四位数,如果该四位数连续小于该四位数以后的五个数且该数是偶数(该四位数以后不满五个数,则不统计),则统计出满足此条件的个数 cnt并把这些四位数按从小到大的顺序存入数组 b中,
34、最后调用写函数 writeDat(),把结果 cnt以及数组 b中符合条件的四位数输出到 OUT.DAT文件中。注意:部分程序已经给出。程序中已定义数组:a200,b200;已定义变量:cnt。请勿改动数据文件 IN.DAT中的任何数据及主函数 main()、读函数 readDat()和写函数 writeDat()的内容。#includestdio.h#define MAX 200int aMAX,bMAX,cnt=0;void jsVal()void readDat()int i;FILE *fp;fp=fopen(“IN.DAT“,“r“);for(i=0;iMAX; i+)fscanf(
35、fp,“%d,“,ai);fclose(fp);void writeDat()FILE *fp;int i;fp=fopen(“OUT.DAT“,“w“);fprintf(fp,“%d/n“,cnt);for(i=0;icnt;i+)fprintf(fp,“%d/n“,bi);fclose(fp);void main()int i;readDat();jsVal();printf(“满足条件的数=%d/n“,cnt);for(i=0; icnt;i+)printf(“%d“,bi);printf(“/n“);writeDat();(分数:20.00)_正确答案:(void jsVal()int
36、 i,j,flag=0;/*循环以遍历数组 a的第 1至倒数第 6个数*/for(i=0;i(MAX-5;i+) /*循环以遍历当前数的后 5个数*/for(j=i+1;j=i+5;j+)if(aiaj) /*若当前数小于后 5个数则设标志 flag为 1*/flag=1;else /*否则设标志 flag为 0并跳出循环*/flag=0;break;if(flag=1ai%2=0) /*若 flag为 1说明当前数小于后 5个数,且为偶数的话*/bcnt=ai;/*把当前数存入数组 b*/cnt+; /*计数值 cnt增 1*/*对数组 b的前 cnt个数进行选择排序*/for(i=0;i(cnt-1;i+)for(j=i+1;j(cnt;j+)if(bibj) /*前面的数大于后面的数则交换,即升序排列*/flag=bi;bi=bj;bj=flag;)解析: