【计算机类职业资格】三级数据库技术机试-244及答案解析.doc
《【计算机类职业资格】三级数据库技术机试-244及答案解析.doc》由会员分享,可在线阅读,更多相关《【计算机类职业资格】三级数据库技术机试-244及答案解析.doc(14页珍藏版)》请在麦多课文档分享上搜索。
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
- 1.请仔细阅读文档,确保文档完整性,对于不预览、不比对内容而直接下载带来的问题本站不予受理。
- 2.下载的文档,不会出现我们的网址水印。
- 3、该文档所得收入(下载+内容+预览)归上传者、原创作者;如果您是本文档原作者,请点此认领!既往收益都归您。
下载文档到电脑,查找使用更方便
5000 积分 0人已下载
下载 | 加入VIP,交流精品资源 |
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 职业资格 三级 数据库技术 244 答案 解析 DOC
