【计算机类职业资格】三级数据库技术机试-238及答案解析.doc
《【计算机类职业资格】三级数据库技术机试-238及答案解析.doc》由会员分享,可在线阅读,更多相关《【计算机类职业资格】三级数据库技术机试-238及答案解析.doc(14页珍藏版)》请在麦多课文档分享上搜索。
1、三级数据库技术机试-238 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:5,分数:100.00)1.函数 ReadDat()实现从 IN.DAT 文件中读取一篇英文文章并存入字符串数组 xx 中。请编写函数encryptChar(),按给定的替代关系对数组 xx 中的所有字符进行替代后,仍存入数组 xx 的对应位置上,最后调用函数 WriteDat(),把结果 xx 输出到 OUT.DAT 文件中。替代关系:f(p)=p*11mod 256(p 是数组中某一个字符的 ASCII 值,f(p)是计算后新字符的 ASCII 值),如果计算后 f(p)值小于等于 32
2、或 f(p)对应的字符是小写字母,则该字符不变,否则将 f(p)所对应的字符进行替代。原始数据文件存放的格式是:每行的宽度均小于 80 个字符。注意:部分源程序已经给出。请勿改动主函数 main()、读数据函数 ReadDat()和输出数据函数 WriteDat()的内容。#includestdio.h#includestring.h#includeconio.h#includectype.hunsigned char xx5080;int maxline=0; /*文章的总行数*/int ReadDat(void);void WriteDat(void);void encryptChar()
3、void main()if(ReadDat()printf(“数据文件 IN.DAT 不能打开!/n/007“);return;encryptChar();WriteDat();int ReadDat(void)FILE *fp;int i=0;unsigned char *p;if(fp=fopen(“IN.DAT“,“r“)=NULL)return 1;while(fgets(xxi,80,fp)!=NULL)p=strchr(xxi,/n);if(p)*p=0;i+;maxline=i;fclose(fp);return 0;void WriteDat(void)FILE *fp;int
4、 i;fp=fopen(“OUT.DAT“,“w“);for(i=0;imaxline;i+)printf(“%s/n“,xxi);fprintf(fp,“%s/n“,xxi);fclose(fp);(分数:20.00)_2.设有 n 个人围坐一圈并按顺时针方向从 1 到 n 编号,从第 s 个人开始进行 1 到 m 的报数,报数到第 m 个人,此人出圈,再从他的下一个人重新开始 1 到 m 的报数,如此进行下去直到所有的人都出圈为止。现要求按出圈次序,每 10 人一组,给出这 n 个人的顺序表。请编写函数 Josegh()实现此功能,并调用函数WriteDat(),把结果 p 输出到 OUT
5、.DAT 文件中。设 n=100,s=1,m=10。(1)将 1 到 n 个人的序号存入一维数组 p 中;(2)若第 i 个人报数后出圈,则将 pi置于数组的倒数第 i 个位置上,而原来第 i+1 个至倒数第 i 个元素依次向前移动一个位置;(3)重复第(2)步直至圈中只剩下 p1为止。注意:部分源程序已经给出。请勿改动主函数 main()和输出数据函数 WriteDat()的内容。#includestdio.h#define N 100#define S 1#define M 10int p100,n,s,m;void WriteDat(void);void Josegh(void)void
6、 main()m=M;n=N;s=S;Josegh();WriteDat();void WriteDat(void)int i;FILE *fp;fp=fopen(“OUT.DAT“,“w“);for(i=N-1;i=0;i-)printf(“%4d“,pi);fprintf(fp,“%4d“,pi);if(i%10=0)printf(“/n“);fprintf(fp,“/n“);fclose(fp);(分数:20.00)_3.现有一个 10 个人 100 行的选票数据文件 IN.DAT,其数据存放的格式是每条记录的长度均为 10 位,第一位表示第一个人的选中情况,第二位表示第二个人的选中情况
7、,以此类推;内容均为字符 0 或 1,1 表示此人被选中,0 表示此人未被选中,若一张选票人数小于等于 5 个人时被认为无效的选票。给定函数ReadDat()的功能是把选票数据读入到字符串数组 xx 中。请编写函数 CountRs()来统计每个人的选票数并把得票数依次存入 yy0到 yy9中。把结果 yy 输出到 OUT.DAT 文件中。注意:部分源程序已经给出。请勿改动主函数 main()、读数据函数 ReadDat()和输出数据函数 WriteDat()的内容。#includestdio.hchar xx10011;int yy10;int ReadDat(void);void Write
8、Dat(void);void CountRs(void)void main()int i;for(i=0;i10;i+)yyi=0;if(ReadDat()printf(“选票数据文件 IN.DAT 不能打开!/n/007“);return;CountRs();WriteDat();int ReadDat(void)FILE *fp;int i;if(fp=fopen(“IN.DAT“,“r“)=NULL)return 1;for(i=0; i100; i+)if(fgets(xxi,12,fp)=NULL)return 1;xxi10=/0;fclose(fp);return 0;void
9、WriteDat(void)FILE *fp;int i;fp=fopen(“OUT.DAT“,“w“);for(i=0; i10; i+)fprintf(fp,“%d/n“,yyi);printf(“第%d 个人的选票数=%d/n“,i+1,yyi);fclose(fp);(分数:20.00)_4.已知数据文件 IN.DAT 中存有 200 个四位数,并已调用读函数 readDat()把这些数存入数组 a 中。请编写函数 jsVal(),其功能是:把千位数字和十位数字重新组成一个新的十位数 ab(新十位数的十位数字是原四位数的千位数字,新十位数的个位数字是原四位数的十位数字),以及把个位数字
10、和百位数字组成另一个新的十位数 cd(新十位数的十位数字是原四位数的个位数字,新十位数的个位数字是原四位数的百位数字),如果 abcd,ab 必须是奇数且不能被 5 整除,cd 必须是偶数,同时两个新数的十位数字均不为零,则将满足此条件的四位数按从大到小的顺序存入数组 b 中,并计算满足上述条件的四位数的个数cnt。最后 main()函数调用写函数 writeDat(),把结果 cnt 以及数组 b 中符合条件的四位数输出到OUT.DAT 文件中。注意:部分源程序已经给出。程序中已定义数组:a200,b200;已定义变量:cnt。请勿改动数据文件 IN.DAT 中的任何数据及主函数 main(
11、)、读函数 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=fopen(“OUT.DAT“,“w“);fprintf(fp,“%d/n“,cnt);for(i=0; icnt;i+)fprintf(fp,
12、“%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 组数据,每组有 3 个数,每个数均是三位数。函数 ReadDat()读取这 200 组数据并存放到结构数组 aa 中。请编写函数 jsSort(),其功能是:要求在 200 组数据中找出条件为每组中的第二个数大于第一个数加第三个数之和,其中满足条件的组数作为
13、函数 jsSort()的返回值,同时把满足条件的数据存入结构数组 bb 中,再对 bb 中的数据按照每组数据的第二个数加第三个之和的大小进行降序排列(第二个数加第三个数的和均不相等),排序后的结果仍重新存入结构数组 bb 中,最后调用函数WriteDat(),把结果 bb 输出到 out.dat 文件中。注意:部分源程序已经给出。请勿改动主函数 main()、读数据函数 ReadDat()和输出数据函数 WriteDat()的内容。#includestdio.h#includestring.h#includeconio.htypedef structint x1,x2,x3;data;data
14、 aa200,bb200;int jsSort()void ReadDat()FILE *in;int i;in=fopen(“in.dat“,“r“);for(i=0; i200;i+)fscanf(in,“%d,%d,%d“,aai.x1,aai.x2,aai.x3);fclose(in);void WriteDat(int count)FILE *out;int i;out=fopen(“out.dat“,“w“);for(i=0; icount;i+)printf(“%d,%d,%d 第二个数+第三个数=%d/n“,bbi.x1,bbi.x2,bbi.x3,bbi.x2+bbi.x3)
15、;fprintf(out,“%d%d%d/n“,bbi.x1,bbi.x2,bbi.x3);fclose(out);void main()int count;ReadDat();count=jsSort(); /*返回满足条件的个数*/WriteDat(count);(分数:20.00)_三级数据库技术机试-238 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:5,分数:100.00)1.函数 ReadDat()实现从 IN.DAT 文件中读取一篇英文文章并存入字符串数组 xx 中。请编写函数encryptChar(),按给定的替代关系对数组 xx 中的所有字符进行替
16、代后,仍存入数组 xx 的对应位置上,最后调用函数 WriteDat(),把结果 xx 输出到 OUT.DAT 文件中。替代关系:f(p)=p*11mod 256(p 是数组中某一个字符的 ASCII 值,f(p)是计算后新字符的 ASCII 值),如果计算后 f(p)值小于等于 32 或 f(p)对应的字符是小写字母,则该字符不变,否则将 f(p)所对应的字符进行替代。原始数据文件存放的格式是:每行的宽度均小于 80 个字符。注意:部分源程序已经给出。请勿改动主函数 main()、读数据函数 ReadDat()和输出数据函数 WriteDat()的内容。#includestdio.h#inc
17、ludestring.h#includeconio.h#includectype.hunsigned char xx5080;int maxline=0; /*文章的总行数*/int ReadDat(void);void WriteDat(void);void encryptChar()void main()if(ReadDat()printf(“数据文件 IN.DAT 不能打开!/n/007“);return;encryptChar();WriteDat();int ReadDat(void)FILE *fp;int i=0;unsigned char *p;if(fp=fopen(“IN.
- 1.请仔细阅读文档,确保文档完整性,对于不预览、不比对内容而直接下载带来的问题本站不予受理。
- 2.下载的文档,不会出现我们的网址水印。
- 3、该文档所得收入(下载+内容+预览)归上传者、原创作者;如果您是本文档原作者,请点此认领!既往收益都归您。
下载文档到电脑,查找使用更方便
5000 积分 0人已下载
下载 | 加入VIP,交流精品资源 |
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 职业资格 三级 数据库技术 238 答案 解析 DOC
