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; )解析: