1、计算机三级数据库技术-133 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.读函数 ReadDat()的功能是从文件 ENG.IN中读取一篇英文文章,存入到字符串数组 xx中。请编写函数encryptChar(),按给定的替代关系对数组 xx中的所有字符进行替换,仍存入数组 xx的对应位置上,最后调用写函数 WritrDat(),把结果 xx输出到文件 PS.DAT中。 替代关系:f(p)=p*11 mod 256(p 是数组 xx中某一个字符的 ASCII码值,f(p)是计算后新字符的 ASCII码值),如果计算后 f(p)的值小于等于
2、 32或 f(p)对应的字符是小写字母,则该字符不变,否则,将 f(p)所对应的字符进行替换。 注意:原始数据文件存放的格式是:每行的宽度均小于 80个字符。请勿改动主函数 main()、读函数ReadDat()和写函数 WriteDat()的内容。 【试题程序】 #include stdio.h #include string.h #include stdlib.h #include ctype.h unsigned char xx50 80 ; int maxline =0 ; / 文章的总行数 int ReadDat (void) ; void WriteDat (void) ; voi
3、d encryptChar () void main () system (“CLS“) ; if (Readmat () printf (“数据文件 ENG. IN 无法打开! n007 “) ; return; encryptChar () ; WriteDat () ; int ReadDat (void) FILE * fp; int i =0 ; unsigned char * p; if (fp = fopen (“ENG. IN“, “r“) = NULL ) return 1 ; while (fgets (xxi, 80, fp) ! =NULL) p = strchr (x
4、xi ,“n“) ; if (p) *p =0; i+; maxline = i; fclose (fp) ; return 0 ; void WriteDat (void) FILE * fp; int i ; fp = fopen (“PS.DAT“, “w“) ; for (i=0; imaxline; i+) printf(“%sn“, xxi); fprintf(fp, “%sn“, xxi); fclose (fp) ; (分数:100.00)_计算机三级数据库技术-133 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.读函数
5、ReadDat()的功能是从文件 ENG.IN中读取一篇英文文章,存入到字符串数组 xx中。请编写函数encryptChar(),按给定的替代关系对数组 xx中的所有字符进行替换,仍存入数组 xx的对应位置上,最后调用写函数 WritrDat(),把结果 xx输出到文件 PS.DAT中。 替代关系:f(p)=p*11 mod 256(p 是数组 xx中某一个字符的 ASCII码值,f(p)是计算后新字符的 ASCII码值),如果计算后 f(p)的值小于等于 32或 f(p)对应的字符是小写字母,则该字符不变,否则,将 f(p)所对应的字符进行替换。 注意:原始数据文件存放的格式是:每行的宽度均
6、小于 80个字符。请勿改动主函数 main()、读函数ReadDat()和写函数 WriteDat()的内容。 【试题程序】 #include stdio.h #include string.h #include stdlib.h #include ctype.h unsigned char xx50 80 ; int maxline =0 ; / 文章的总行数 int ReadDat (void) ; void WriteDat (void) ; void encryptChar () void main () system (“CLS“) ; if (Readmat () printf (
7、“数据文件 ENG. IN 无法打开! n007 “) ; return; encryptChar () ; WriteDat () ; int ReadDat (void) FILE * fp; int i =0 ; unsigned char * p; if (fp = fopen (“ENG. IN“, “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 ; voi
8、d WriteDat (void) FILE * fp; int i ; fp = fopen (“PS.DAT“, “w“) ; for (i=0; imaxline; i+) printf(“%sn“, xxi); fprintf(fp, “%sn“, xxi); fclose (fp) ; (分数:100.00)_正确答案:()解析:void encryptChar() int i,j; /*定义循环控制变量*/ int str; /*存储字符串的长度*/ char ch; /*存储当前取得的字符*/ for(i=0;imaxline;i+) /*以行为单位获取字符*/ str=strl
9、en(xxi); /*求得当前行的字符串长度*/ for(j=0;jstr;j+) /*依次取各行的每个字符*/ ch=xxij*11%256; if (ch=“a“ else xxij=ch; /*否则用新字符来替代这个字符*/ 考点 本题考查对字符数组中字符计算和替换。考查的知识点主要包括:字符串数组的访问,字符ASCII码的算术运算,if 判断结构以及逻辑表达式。 解析 此题属于字符替代问题。分析题干要求,可以归纳出 3个关键点:关键点 1如何对字符数组的元素逐个访问;关键点 2如何根据给出的函数替代关系“f(p)p*11 mod 256“对字符进行计算;关键点 3根据条件(本题为“计算后 f(p)的值小于等于 32或 f(p)对应的字符是小写字母“)对计算结果进行判断,并分别对满足与不满足条件的情况进行处理。 本题与前两题思路相同,不同的是本题的替代条件为计算后的 f(p)值不满足小于等于 32或 f(p)对应的字符不是小写字母。 根据函数替代关系对字符进行运算,if 判断结构中逻辑表达式。