欢迎来到麦多课文档分享! | 帮助中心 海量文档,免费浏览,给你所需,享你所想!
麦多课文档分享
全部分类
  • 标准规范>
  • 教学课件>
  • 考试资料>
  • 办公文档>
  • 学术论文>
  • 行业资料>
  • 易语言源码>
  • ImageVerifierCode 换一换
    首页 麦多课文档分享 > 资源分类 > DOC文档下载
    分享到微信 分享到微博 分享到QQ空间

    【计算机类职业资格】计算机三级数据库技术-5及答案解析.doc

    • 资源ID:1337499       资源大小:45KB        全文页数:5页
    • 资源格式: DOC        下载积分:5000积分
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    二维码
    微信扫一扫登录
    下载资源需要5000积分(如需开发票,请勿充值!)
    邮箱/手机:
    温馨提示:
    如需开发票,请勿充值!快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如需开发票,请勿充值!如填写123,账号就是123,密码也是123。
    支付方式: 支付宝扫码支付    微信扫码支付   
    验证码:   换一换

    加入VIP,交流精品资源
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    【计算机类职业资格】计算机三级数据库技术-5及答案解析.doc

    1、计算机三级数据库技术-5 及答案解析(总分:100.00,做题时间:90 分钟)一、B上机题/B(总题数:5,分数:100.00)1.函数 ReadDat()实现从 IN.DAT文件中读取一篇英文文章并存入字符串数组 xx中。请编写函数StrCharJR(),其函数的功能是:以行为单位把字符串中所有字符的 ASCII值右移 4位,然后把右移后的字符 ASCII值再加上原字符的 ASCII值,得到新的字符仍存入原字符串对应的位置上。最后把已处理的字符串仍按行重新存入字符串数组 xx中,最后调用函数 WriteDat(),把结果 xx输出到 OUT.DAT文件中。 原始数据文件存放的格式是:每行的

    2、宽度均小于 80个字符(含标点符号和空格)。 注意:部分程序已经给出。 请勿改动主函数 main()、读数据函数 ReadDat()和输出数据函数 WriteDat()的内容。 #include stdio.h #include string.h #include conio.h char xx 5080; int maxline=0; /*文章的总行数*/ int ReadDat(void); void WriteDat(void); void StrCharjR(void) void main() if (ReadDat() printf(“数据文件 IN.DAT不能打开!/n/007“)

    3、; return; StrCharjR(); WriteDat(); int ReadDat(void) FILE *fp; int i=0; char *p; if(fp=fopen(“IN.DAT“,“r“)=NULL) return 1; while(fgets(xxi,80,fp)!=NULL) p=strchr(xxi,/n); if(p) i+; maxline=i; fclose(fp); return 0; void WriteDat(void) FILE *fp; int i; fp=fopen(“OUT.DAT“,“w“); for(i=0;imaxline;i+) fpr

    4、intf(fp,“%s/n“,xxi); fclose(fp);(分数:20.00)_2.函数 ReadDat()的功能是实现从 IN.DAT文件中读取一篇英文文章并存入字符串数组 xx中。请编写函数ChA(),其功能是:以行为单位把字符串中的第一个字符的 ASCII值加第二个字符的 ASCII值,得到第一个新字符,第二个字符的 ASCII值加第三个字符的 ASCII值,得到第二个新字符,依此类推,一直处理到倒数第二个字符,最后一个字符的 ASCII值加原第一个字符的 ASCII值,得到最后一个新的字符。得到的新字符分别存放在原字符串对应的位置上,最后把已处理的字符串逆转后按行重新存入字符串数

    5、组 xx中,最后调用函数 WriteDat(),把结果 xx输出到 OUT.DAT文件中。 原始数据文件存放的格式是:每行的宽度均小于 80个字符(含标点符号和空格)。 注意:部分源程序已给出。 请勿改动主函数 main()、读数据函数 ReadDat()和输出数据函数 WriteDat()的内容。 #include stdio.h #include string.h #include conio.h char xx5080; int maxline=0; /*文章的总行数*/ int ReadDat(void); void WriteDat(void); void ChA(void) voi

    6、d main() if (ReadDat() printf(“数据文件IN.DAT不能打开!/n/007“); return; ChA(); WriteDat(); int ReadDat(void) FIIE *fp; int i=0; char *p; if (fp=fopen(“IN.DAT“,“r“)=NULL) return 1; while (fgets(xxi,80,fp)!=NULL) p=strchr(xxi,/n); if(p) i+; maxline=i; fclose(fp); return 0; void WriteDat(void) FILE *fp; int i;

    7、 fp=fopen(“OUT.DAT“,“w“); for(i=0;imaxline;i+) printf(“%s/n“,xxi); fprintf(fp,“%s/n“,xxi); fclose(fp); (分数:20.00)_3.函数 ReadDat()实现从 IN.DAT文件中读取一篇英文文章并存入字符串数组 xx中。请编写函数encryptChar(),按给定的替代关系对数组 xx中的所有字符进行替代后,仍存入数组 xx的对应的位置上,最后调用函数 WriteDat(),把结果 xx输出到 OUT.DAT文件中。 替代关系:f(p)=p*11 mod 256(p 是数组中某一个字符的 A

    8、SCII值,f(p)是计算后新字符的 ASCII值),如果原字符的 ASCII值是偶数或计算后f(p)值小于等于 32,则该字符不变,否则将 f(p)所对应的字符进行替代。 原始数据文件存放的格式是:每行的宽度均小于 80个字符。 注意:部分程序已经给出。 请勿改动主函数 main()、读数据函数ReadDat()和输出数据函数 WriteDat()的内容。 #include stdio.h #include string.h #include conio.h #include ctype.h unsigned char xx5080; int maxline=0; /*文章的总行数*/ in

    9、t 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.DAT“,“r“)=NULL) return 1; while (fgets(xxi,80,fp)!=NULL) p=strchr(xxi,/n)

    10、; if(p) i+; maxline=i; fclose(fp); return 0; void WriteDat(void) FILE *fp; int i; fp=fopen(“OUT.DAT“,“w“); for(i=0;imaxline;i+) printf(“%s/n“,xxi); fprintf(fp,“%s/n“,xxi); fclose(fp); (分数:20.00)_4.编写函数 findStr(),该函数统计一个长度为 2的子字符串在另一个字符串中出现的次数。例如,假定输入的字符串为“asd asasdfg asd as zx67 asd mklo“,子字符串为“as“,

    11、函数返回值为 6。 函数ReadWrite()实现从 in.dat文件中读取两个字符串,并调用函数 findStr(),最后,把结果输出到out.dat文件中。 注意:部分程序已经给出。 请勿改动主函数 main()和其他函数中的任何内容,仅在函数 findStr()的花括号中填入你编写的若干语句。 #include stdio.h #include string.h #include conio.h int findStr (char *str,char *substr) void ReadWrite() char str81,substr10,ch; int n,len,i=0; FILE

    12、 *rf,*wf; rf=fopen(“in.dat“,“r“); wf=fopen(“out.dat“,“w“); while(i25) fgets(strt 81,rf); fgets(substr,10,rf); len=strlen(substr)-1; ch=substrlen; if (ch=/n|ch=0x1a) substrlen=0; n=findStr(str,substr); fprintf(wf,“%d/n“,n); i+; fclose(rf); fclose(wf); main () char str81,substr10; int n; gets(str); ge

    13、ts(substr); puts(str); puts(substr); n=findStr(str,substr); printf(“n=%d/n“,n); ReadWrite();(分数:20.00)_5.编写函数 jsValue(),其功能是:求 Fibonacci数列中大于 t的最小的一个数,结果由函数返回。其中Fibonacci数列 F(n)的定义为: F(0)=0,F(1)=1 F(n)=F(n-1)+F(n-2) 最后调用函数 writeDat()从in.dat中读取 50个数据 t,分别得出结果,且把结果输出到 out.dat文件中。 例如:当 t=1000时,函数值为:159

    14、7。 注意:部分程序已经给出。 请勿改动主函数 main()和写函数 writeDat()的内容。 #include stdio.h int jsValue(int t) void writeDat() FILE *in,*out; int i,n,s; in=fopen(“in.dat“,“r“); out=fopen(“out.dat“,“w“); for(i=0;i50;i+) fscanf(in,“%d,“, s=jsValue(n); fprintf(out,“%d/n“,s); fclose(in); fclose(out); main() int n; n=1000; print

    15、f(“t=%d,f=%d/n“,n,jsValue(n); writeDat(); (分数:20.00)_计算机三级数据库技术-5 答案解析(总分:100.00,做题时间:90 分钟)一、B上机题/B(总题数:5,分数:100.00)1.函数 ReadDat()实现从 IN.DAT文件中读取一篇英文文章并存入字符串数组 xx中。请编写函数StrCharJR(),其函数的功能是:以行为单位把字符串中所有字符的 ASCII值右移 4位,然后把右移后的字符 ASCII值再加上原字符的 ASCII值,得到新的字符仍存入原字符串对应的位置上。最后把已处理的字符串仍按行重新存入字符串数组 xx中,最后调用

    16、函数 WriteDat(),把结果 xx输出到 OUT.DAT文件中。 原始数据文件存放的格式是:每行的宽度均小于 80个字符(含标点符号和空格)。 注意:部分程序已经给出。 请勿改动主函数 main()、读数据函数 ReadDat()和输出数据函数 WriteDat()的内容。 #include stdio.h #include string.h #include conio.h char xx 5080; int maxline=0; /*文章的总行数*/ int ReadDat(void); void WriteDat(void); void StrCharjR(void) void m

    17、ain() if (ReadDat() printf(“数据文件 IN.DAT不能打开!/n/007“); return; StrCharjR(); WriteDat(); int ReadDat(void) FILE *fp; int i=0; char *p; if(fp=fopen(“IN.DAT“,“r“)=NULL) return 1; while(fgets(xxi,80,fp)!=NULL) p=strchr(xxi,/n); if(p) i+; maxline=i; fclose(fp); return 0; void WriteDat(void) FILE *fp; int

    18、i; fp=fopen(“OUT.DAT“,“w“); for(i=0;imaxline;i+) fprintf(fp,“%s/n“,xxi); fclose(fp);(分数:20.00)_正确答案:(void StrCharJR(void) int i,j,strl; /*循环以遍历文章的每一行*/ for (i=0;imaxline;i+) strl=strlen(xxi); for (j=0;jstrl;j+) /*循环以遍历当前行的每一个字符*/ xxij+=xxij4; /*将每个字符按题目的要求进行替换*/ )解析:2.函数 ReadDat()的功能是实现从 IN.DAT文件中读取

    19、一篇英文文章并存入字符串数组 xx中。请编写函数ChA(),其功能是:以行为单位把字符串中的第一个字符的 ASCII值加第二个字符的 ASCII值,得到第一个新字符,第二个字符的 ASCII值加第三个字符的 ASCII值,得到第二个新字符,依此类推,一直处理到倒数第二个字符,最后一个字符的 ASCII值加原第一个字符的 ASCII值,得到最后一个新的字符。得到的新字符分别存放在原字符串对应的位置上,最后把已处理的字符串逆转后按行重新存入字符串数组 xx中,最后调用函数 WriteDat(),把结果 xx输出到 OUT.DAT文件中。 原始数据文件存放的格式是:每行的宽度均小于 80个字符(含标

    20、点符号和空格)。 注意:部分源程序已给出。 请勿改动主函数 main()、读数据函数 ReadDat()和输出数据函数 WriteDat()的内容。 #include stdio.h #include string.h #include conio.h char xx5080; int maxline=0; /*文章的总行数*/ int ReadDat(void); void WriteDat(void); void ChA(void) void main() if (ReadDat() printf(“数据文件IN.DAT不能打开!/n/007“); return; ChA(); Write

    21、Dat(); int ReadDat(void) FIIE *fp; int i=0; char *p; if (fp=fopen(“IN.DAT“,“r“)=NULL) return 1; while (fgets(xxi,80,fp)!=NULL) p=strchr(xxi,/n); if(p) i+; maxline=i; fclose(fp); return 0; void WriteDat(void) FILE *fp; int i; fp=fopen(“OUT.DAT“,“w“); for(i=0;imaxline;i+) printf(“%s/n“,xxi); fprintf(f

    22、p,“%s/n“,xxi); fclose(fp); (分数:20.00)_正确答案:(void ChA(void) int i,j,k,str; char ch; /*循环以遍历英文文章的每一行*/ for (i=0;imaxline;i+) str=strlen(xxi); ch=xxi0; /*保存当前行第 1个字符*/ /*循环以遍历当前行除最后一个字符以外的所有字符*/ for (j=0;jstr-1;j+) xxij+=xxij+1; /*将这些字符累加上紧挨其后的一个字符*/ xxistr-1+=ch;/*将最后一个字符累加上前面保存的第 1个字符*/ for (j=0,k=st

    23、r-1;jstr/2;j+,k-) /*通过双循环变量从首尾开始同时遍历当前行,交换相对位置的值以实现逆转*/ ch=xxij; xxij=xxik; xxik=ch; )解析:3.函数 ReadDat()实现从 IN.DAT文件中读取一篇英文文章并存入字符串数组 xx中。请编写函数encryptChar(),按给定的替代关系对数组 xx中的所有字符进行替代后,仍存入数组 xx的对应的位置上,最后调用函数 WriteDat(),把结果 xx输出到 OUT.DAT文件中。 替代关系:f(p)=p*11 mod 256(p 是数组中某一个字符的 ASCII值,f(p)是计算后新字符的 ASCII值

    24、),如果原字符的 ASCII值是偶数或计算后f(p)值小于等于 32,则该字符不变,否则将 f(p)所对应的字符进行替代。 原始数据文件存放的格式是:每行的宽度均小于 80个字符。 注意:部分程序已经给出。 请勿改动主函数 main()、读数据函数ReadDat()和输出数据函数 WriteDat()的内容。 #include stdio.h #include string.h #include conio.h #include ctype.h unsigned char xx5080; int maxline=0; /*文章的总行数*/ int ReadDat(void); void Wri

    25、teDat(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.DAT“,“r“)=NULL) return 1; while (fgets(xxi,80,fp)!=NULL) p=strchr(xxi,/n); if(p) i+; maxline=i; fc

    26、lose(fp); return 0; void WriteDat(void) FILE *fp; int i; fp=fopen(“OUT.DAT“,“w“); for(i=0;imaxline;i+) printf(“%s/n“,xxi); fprintf(fp,“%s/n“,xxi); fclose(fp); (分数:20.00)_正确答案:(void encryptChar() int i; char *pf; /*循环以遍历英文文章的每一行*/ for (i=0;imaxline;i+) pf=xxi; /*以字符指针指向当前行行首*/ while(*pf!=0) /*若所指字符不为

    27、0(即字符串结束标志)则循环*/ /*若所指字符为奇数且依题意计算后大于 32,则用计算结果替换之*/ if(*pf%2 pf+; /*让指针指向下一个字符*/ )解析:4.编写函数 findStr(),该函数统计一个长度为 2的子字符串在另一个字符串中出现的次数。例如,假定输入的字符串为“asd asasdfg asd as zx67 asd mklo“,子字符串为“as“,函数返回值为 6。 函数ReadWrite()实现从 in.dat文件中读取两个字符串,并调用函数 findStr(),最后,把结果输出到out.dat文件中。 注意:部分程序已经给出。 请勿改动主函数 main()和其

    28、他函数中的任何内容,仅在函数 findStr()的花括号中填入你编写的若干语句。 #include stdio.h #include string.h #include conio.h int findStr (char *str,char *substr) void ReadWrite() char str81,substr10,ch; int n,len,i=0; FILE *rf,*wf; rf=fopen(“in.dat“,“r“); wf=fopen(“out.dat“,“w“); while(i25) fgets(strt 81,rf); fgets(substr,10,rf);

    29、len=strlen(substr)-1; ch=substrlen; if (ch=/n|ch=0x1a) substrlen=0; n=findStr(str,substr); fprintf(wf,“%d/n“,n); i+; fclose(rf); fclose(wf); main () char str81,substr10; int n; gets(str); gets(substr); puts(str); puts(substr); n=findStr(str,substr); printf(“n=%d/n“,n); ReadWrite();(分数:20.00)_正确答案:(i

    30、nt findStr(char *str,char *substr) int n; char *p, *r; n=0; while(*str) /*以指针 str循环遍历其所指字符串*/ p=str; /*用指针 p指向当前字符*/ r=substr; while(*r) /*以指针r循环遍历 substr所指字符串*/ if(*r=*p) /*如果 p和 r所指字符相同则继续比较*/ r+; p+; else /*一旦碰到不同字符则跳出循环*/ break; /*如果上面循环是正常结束(即 r指向字符串结束标志/0)*/ /*证明从 str当前所指位置起与 substr所指字符串中的所有字符

    31、一一匹配*/ if (*r=/0) n+; /*所以此时找到一个子串,计数值 n增 1*/ str+; /*将指向 str移到下一个位置,继续遍历字符串*/ return n; )解析:5.编写函数 jsValue(),其功能是:求 Fibonacci数列中大于 t的最小的一个数,结果由函数返回。其中Fibonacci数列 F(n)的定义为: F(0)=0,F(1)=1 F(n)=F(n-1)+F(n-2) 最后调用函数 writeDat()从in.dat中读取 50个数据 t,分别得出结果,且把结果输出到 out.dat文件中。 例如:当 t=1000时,函数值为:1597。 注意:部分程序

    32、已经给出。 请勿改动主函数 main()和写函数 writeDat()的内容。 #include stdio.h int jsValue(int t) void writeDat() FILE *in,*out; int i,n,s; in=fopen(“in.dat“,“r“); out=fopen(“out.dat“,“w“); for(i=0;i50;i+) fscanf(in,“%d,“, s=jsValue(n); fprintf(out,“%d/n“,s); fclose(in); fclose(out); main() int n; n=1000; printf(“t=%d,f=%d/n“,n,jsValue(n); writeDat(); (分数:20.00)_正确答案:(int jsValue(int t) int f1=0,f2=1,fn; /*取 f1和 f2的初值分别为 0和 1*/ fn=f1+f2; /*初始化 fn为 f1+f2*/ while(fn=t) /*循环计算 fn的值,直到 fn大于 t*/ /*让 f1和 f2分别等于它们对应 Fibonacci数列的下一个值*/ f1=f2; f2=fn; fn=f1+f2; /*计算出一个新的值到 fn*/ return fn; )解析:


    注意事项

    本文(【计算机类职业资格】计算机三级数据库技术-5及答案解析.doc)为本站会员(testyield361)主动上传,麦多课文档分享仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知麦多课文档分享(点击联系客服),我们立即给予删除!




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
    备案/许可证编号:苏ICP备17064731号-1 

    收起
    展开